面试题01.06 字符串压缩

思路
这道题给出一个字符串,将重复的字符压缩成字符*出现次数形式的字符串。
双指针法,一个指针指向新出现的字符,另一个指向他的下一个字符,比较两个字符,若相等count++,下一个指针右移,不等则输出当前状态的count和字符。

tips
1.这道题用res=res+S[m]+to_string(count)会显示内存超出限制。改为res+=S[m]+to_string(count)就不超出限制了。可见平时要养成良好简约的代码习惯
2.res是字符串时,可以使用res.push_back向字符串末尾加入一个字符;也可以用res.append()向后面加入一个字符串。(append只能用于加字符串,如果是int类型或者是单个字符,都要先用to_string转为字符串再进行插入)

代码

string compressString(string S) {
        int size=S.size();
        if(size<=1){return S;}
        string res="";
        string cur="";
        int count=1,m=0,n=1;
        while(m<size){
            while(S[m]==S[n]&&n<size){
                count++;
                n++;
            }
            
            res.append(to_string(S[m]));
            //respush_back(S[m]);
            res.append(to_string(count));
            //res+=S[m]+to_string(count);//上面两句 改成这样也行
            m=n;
            n++;
            count=1;
        }
        if(res.size()>=S.size()){return S;}
        return res;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值