C语言程序设计第四版(何钦铭、颜晖)第八章之字符串压缩

【例8-8】输入一个长度小于80的字符串,按规则对字符串进行压缩,输出压缩后的字符串。压缩规则是:如果某个字符x连续出现n(n>1)个,则将这n个字符替换为"nx"的形式;否则保持不变。

复制代码
#include<stdio.h>
#define MAXN 80
#define MAXM 160
int main()
{
    char str[MAXN],res[MAXM],i,k,n;
    i=k=0;
    while((str[i]=getchar())!='#'){
        i++;
    }
    str[i]='\0';
    i=0;
    while(str[i]!='\0'){
        n=1;
        while(str[i]==str[i+n]){
            n++;
        }
        if(n>1){
            res[k++]=n+'0';
        }
        res[k++]=str[i];
        i=i+n;
    }
    res[k]='\0';
    k=0;
    while(res[k]!='\0'){
        putchar(res[k]);
        k++;
    }
	return 0;
}

输入样例:qqqwaaadcxsss#

输出结果:3qw3adcx3s

相关推荐
单车少年ing2 小时前
一个编码BUG
算法·bug
努力中的编程者2 小时前
哈希表(C语言底层实现)
c语言·数据结构·c++·算法·哈希算法·散列表
CoovallyAIHub2 小时前
ICLR 2026 | MRAD:不拟合直接查表,零样本工业缺陷检测新范式,16 数据集均值最优
深度学习·算法·计算机视觉
摆烂小白敲代码2 小时前
【数据结构与算法】汉诺塔问题(C++)
c语言·开发语言·数据结构·c++·算法·hanoi·汉诺塔问题
炸膛坦客2 小时前
单片机/C语言八股:(八)指针函数 和 函数指针
c语言·单片机
Trouvaille ~2 小时前
【递归、搜索与回溯】专题(八):记忆化搜索——从暴力递归到动态规划的桥梁
c++·算法·leetcode·青少年编程·面试·蓝桥杯·动态规划
Pu_Nine_92 小时前
深入理解 ES6 Map 数据结构:从理论到实战应用
前端·javascript·数据结构·es6
飞Link3 小时前
降维打击聚类难题:高斯混合模型 (GMM) 深度解析与实战
人工智能·算法·机器学习·数据挖掘·聚类
沐苏瑶3 小时前
Java数据结构-LinkedList与链表
java·数据结构·链表