zoukankan      html  css  js  c++  java
  • 字符串压缩-连续字符压缩并输出次数

    一、算法描述

        给定一个字符串,压缩其连续出现的字符,并输出连续出现的次数,输出顺序与原字符出现的顺序一致,如果只出现一次则不输出次数, 例如: 输入:CCCCDDE, 输出:4C2DE

    二、算法思路

        通过分析可得出,此算法的关键是统计连续出现字符的次数,并输出,这需要借助于一个临时的字符串来输出结果

    三、算法代码

    #include <iostream>
    #include <cstring>
    #include <cstdio>
    #include <cstdlib>
    using namespace std;
    //统计字符串中重复的字符并将重复出现的次数和字符输出,例如: ccccdde, 4c2de
    void count_repeat_char(char *str, char *tstr)
    {
        int cnt=0,k=0;
        char *p=str,*q=p;
        while(*p)
        {
            while(*p==*q)
            {
                cnt++;
                p++;
            }
            if(cnt!=1)
            {
                tstr[k++]=cnt+'0';
                tstr[k++]=*q;
            }
            else{
                tstr[k++]=*q;
            }
            cnt=0;
            q=p;
        
        }
    }
    
    int main()
    {
        char s[256]="ccccddeffff";
        char *pstr=new char[256];
        memset(pstr,0,sizeof(char)*256);
        count_repeat_char(s,pstr);
        cout<<pstr<<endl;
        return 0;
    }
  • 相关阅读:
    网页瀑布流收集
    Docker
    CI/CD/Jenkins
    ckplayer获取播放时长一
    aliplay获取播放时长
    06 intent flag三种属性
    06 Activity隐式跳转
    06 Activity显示跳转
    06 Activity的启动模式 Intent的七大属性的总结
    06 Activity OnNewIntent方法
  • 原文地址:https://www.cnblogs.com/ballwql/p/4941287.html
Copyright © 2011-2022 走看看