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

相关推荐
cpp_25015 分钟前
B3873 [GESP202309 六级] 小杨买饮料
数据结构·c++·算法·动态规划·题解·洛谷
2301_789015629 分钟前
C++11新增特性:可变参数模板、lambda表达式、function包装器、bind绑定、defult和delete
c语言·开发语言·c++·算法·c++11·万能引用
Ahtacca10 分钟前
基于决策树算法的动物分类实验:Mac环境复现指南
python·算法·决策树·机器学习·ai·分类
x_xbx11 分钟前
LeetCode:567. 字符串的排列
算法·leetcode·职场和发展
沛沛rh4517 分钟前
力扣 42. 接雨水 - 高效双指针解法(Rust实现)详细题解
算法·leetcode·rust
tankeven28 分钟前
HJ158 挡住洪水
c++·算法
PyHaVolask41 分钟前
顺序栈:基于数组的实现
数据结构·顺序栈
Wect44 分钟前
LeetCode 190. 颠倒二进制位:两种解法详解
前端·算法·typescript
刘永鑫Adam1 小时前
BiB | 蒋超实验室开发 Kun-peng(鲲鹏):实现可扩展且准确的泛域宏基因组分类
人工智能·算法·机器学习·分类·数据挖掘
Yupureki1 小时前
《Linux网络编程》1.网络基础
linux·运维·服务器·c语言·网络·c++