用C语言实现数据压缩

本文介绍了一个C语言程序,用于输入一个字符数组,统计连续出现的abc或d字符的计数,并在计数超过3时输出计数值,否则直接输出字符。
摘要由CSDN通过智能技术生成

334799ecef6c4161aad253e87a1cb0a2.png

81ff498f00904ba9bea4ad63dc7ccd0b.png 

63d714ce53fd4a38b58883f2f74f5edd.png 

 5efaa8c9ba9f47d995708ecba65d8a53.png

49d37f303f6840daab7aec8a4fbbb750.png

 

 代码部分

 #define _CRT_SECURE_NO_WARNINGS

#include<stdio.h>

#include<stdlib.h>

 

int main()

{

 char ch[21],s=0;

 int num = 0,counta=1,countb=1,countc=1,countd=1,n=0;

 for (num = 1; num < 21; num++)

 {

  scanf("%c", &ch[num]);

 }

 

 for (num = 1; num < 21; num++)

 {

  

  if (ch[num] == 'a' && ch[num] == ch[num - 1])

  {

   counta++;

   if (ch[num + 1] != 'a' )

   {

    if (counta >= 3)

    {

     printf("%d", counta);

    }

    else

    {

     printf("a");

    }

    counta = 0;

   }

 

  }

  else

  if (ch[num] == 'b' && ch[num] == ch[num - 1])

  {

   countb++;

   if (ch[num + 1] != 'b')

   {

    if (countb >= 3)

    {

     printf("%d", countb);

    }

    else

    {

     printf("b");

    }

    countb = 0;

   }

 

  }

  else

   if (ch[num] == 'c' && ch[num] == ch[num - 1])

   {

    countc++;

    if (ch[num + 1] != 'c')

    {

     if (countc >= 3)

     {

      printf("%d", countc);

     }

     else

     {

      printf("c");

     }

     countc = 0;

    }

 

   }

   else

    if (ch[num] == 'd' && ch[num] == ch[num - 1])

    {

     countd++;

     if (ch[num + 1] != 'd')

     {

      if (countd >= 3)

      {

       printf("%d", countd);

      }

      else

      {

       printf("d");

      }

      countd = 0;

     }

 

    }

 

 

 

    else

     {

     printf("%c", ch[num]);

    }

    

 

 }

 system("pause");

}

运行结果9c9ae711bdc241b1ae2ae5d9493dae0a.png

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值