2019年06月19日(星期三)  农历:己亥年五月十七
  • 首页
  • JAVA
  • 将字符串中连续出现的重复字母进行压缩

作者:三年。分类: JAVA

通过键盘输入一串小写字母(a~z)组成的字符串。请编写一个字符串压缩程序,将字符串中连续出现的重复字母进行压缩,并输出压缩后的字符串。

压缩规则:

1、仅压缩连续重复出现的字符。比如字符串"abcbc"由于无连续重复字符,压缩后的字符串还是"abcbc".

2、压缩字段的格式为"字符重复的次数+字符".例如:字符串"xxxyyyyyyz"压缩后就成为"3x6yz".

要求实现函数:

void stringZip(const char *pInputStr, long lInputLen, char *pOutputStr);

输入pInputStr: 输入字符串lInputLen: 输入字符串长度

输出 pOutputStr: 输出字符串,空间已经开辟好,与输入字符串等长;

示例

输入:"cccddecc" 输出:"3c2de2c"

输入:"adef" 输出:"adef"

输入:"pppppppp" 输出:"8p"

*/

#include

#include

#include

#include

using namespace std;

#define N 1024

void print(char *p)

{

if(p!=NULL)

{

int n=strlen(p);

for(int i=0; i1) append(pOutputStr,count,j);

append(pOutputStr,tmp,j);

count=1;

tmp=pInputStr[i];

}

}

if(count>1) append(pOutputStr,count,j);

append(pOutputStr,tmp,j);

print(pOutputStr);

}

int main()

{

char* pInputStr=new char[N];

int lInputLen;

char* pOutputStr;

cin》pInputStr;

lInputLen=strlen(pInputStr);

stringZip(pInputStr,lInputLen,pOutputStr);

}


温馨提示如有转载或引用以上内容之必要,敬请将本文链接作为出处标注,谢谢合作!

已有 0/1274 人参与

发表评论:



手Q扫描加入Java初学者群