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语言能够有所帮助。