一、算法描述
给定一个字符串,压缩其连续出现的字符,并输出连续出现的次数,输出顺序与原字符出现的顺序一致,如果只出现一次则不输出次数, 例如: 输入:CCCCDDE, 输出:4C2DE
二、算法思路
通过分析可得出,此算法的关键是统计连续出现字符的次数,并输出,这需要借助于一个临时的字符串来输出结果
三、算法代码
#include <iostream> #include <cstring> #include <cstdio> #include <cstdlib> using namespace std; //统计字符串中重复的字符并将重复出现的次数和字符输出,例如: ccccdde, 4c2de void count_repeat_char(char *str, char *tstr) { int cnt=0,k=0; char *p=str,*q=p; while(*p) { while(*p==*q) { cnt++; p++; } if(cnt!=1) { tstr[k++]=cnt+'0'; tstr[k++]=*q; } else{ tstr[k++]=*q; } cnt=0; q=p; } } int main() { char s[256]="ccccddeffff"; char *pstr=new char[256]; memset(pstr,0,sizeof(char)*256); count_repeat_char(s,pstr); cout<<pstr<<endl; return 0; }