C语言字符串快速压缩算法代码
通过键盘输入一串小写字母(a~z)组成的字符串。
请编写一个字符串压缩程序,将字符串中连续出席的重复字母进行压缩,并输出压缩后的字符串。
压缩规则:
1、仅压缩连续重复出现的字符。比如字符串”abcbc”由于无连续重复字符,压缩后的字符串还是”abcbc”。
2、压缩字段的格式为”字符重复的次数+字符”。例如:字符串”xxxyyyyyyz”压缩后就成为”3x6yz”。
示例
输入:“cccddecc”输出:“3c2de2c”
输入:“adef”输出:“adef”
输入:“pppppppp”输出:“8p”
主要说来就是进行字符串处理类的问题,主要涉及到:
1.字符串的输入与输出;
2.基本常用的C语言的字符串的函数使用;
3.对于多重情况的考虑;
4.将数字转换成字符串并进行拼接;
#include<stdio.h> #include<string.h> #include<stdlib.h> intmain() { charstr[100]={'\0'}; charres[100]={'\0'}; scanf("%s",str); intlength=strlen(str); inti=0,j=0,k=0; intcount=0; do { if(i<length&&str[i++]==str[j]) count++; if(str[i]!=str[j]) { if(count<=1) res[k++]=str[j]; else { if(count>1) { chartemp[10]={'\0'}; itoa(count,temp,10); strcpy(res+k,temp); k+=strlen(temp); res[k++]=str[j]; } } j=i; count=0; } }while(i<length); res[k]='\0'; printf("Theresultis:%s\n",res); return0; }
以上就是本文给大家分享的字符串压缩算法的全部内容了,希望对大家学习C语言能够有所帮助。