Problem Description
给你一个由大写字母组成的组成的字符串,你可以用如下规则对其进行编码:
1、 包含K个相同字母的连续字符串可以用KX表示,其中X是相同的字母。
2、 如果K为1,不输出K
Input
输入有多组,直到文件结束。每组一个字符串,长度为10000以内
Output
输出编码后的字符串。
Sample Input
ABC
ABBCCC
Sample Output
ABC
A2B3C
#include <stdio.h>
int main()
{
char s[10000];
int cnt,mark;
int i;
while(gets(s)!=NULL)
{
cnt=1; //用来记数
mark=0; //用来做标记
for(i=0;s[i]!='\0';i++)
{
if(s[i]==s[i+1]) //当当前单元与下一单元相等时,计数+1,并且让标记改变
{
cnt++;
mark=1;
}
else if(mark==0) //如果上面的if没执行,记号不改变,表明此字母只有一个,只输出字母
{
printf("%c",s[i]);
}
else //如果上面的if执行若干次后,表示某字母已经被计数数次,此时的mark=1,当下一单元与本单元不相等后,会因mark=1跳过上面的else if 执行这一句,输出计数大于2的字母
{
printf("%d%c",cnt,s[i]);
cnt=1;
mark=0; //输出后计数初始化,标记初始化,继续循环
}
}
printf("\n");
}
return 0;
}