C语言字符串压缩算法代码演示
发布时间:2020-12-16 07:46:55 所属栏目:百科 来源:网络整理
导读:今天PHP站长网 52php.cn把收集自互联网的代码分享给大家,仅供参考。 通过键盘输入一串小写字母(a~z)组成的字符串。 请编写一个字符串压缩程序,将字符串中连续出席的重复字母进行压缩,并输出压缩后的字符串。 压缩规则
以下代码由PHP站长网 52php.cn收集自互联网 现在PHP站长网小编把它分享给大家,仅供参考
通过键盘输入一串小写字母(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> int main() { char str[100] = {' '}; char res[100] = {' '}; scanf("%s",str); int length = strlen(str); int i=0,j=0,k=0; int count = 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) { char temp[10] = {' '}; itoa(count,temp,10); strcpy(res+k,temp); k+=strlen(temp); res[k++] = str[j]; } } j = i; count = 0; } }while(i<length); res[k] = ' '; printf("The result is : %sn",res); return 0; } 以上内容由PHP站长网【52php.cn】收集整理供大家参考研究 如果以上内容对您有帮助,欢迎收藏、点赞、推荐、分享。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |