面试题 01.06. 字符串压缩


面试题 01.06. 字符串压缩

字符串压缩。利用字符重复出现的次数,编写一种方法,实现基本的字符串压缩功能。比如,字符串 aabcccccaaa 会变为 a2b1c5a3。若“压缩”后的字符串没有变短,则返回原先的字符串。你可以假设字符串中只包含大小写英文字母(a 至 z)。

示例 1:

输入:”aabcccccaaa”

输出:”a2b1c5a3”

示例 2:

输入:”abbccd”

输出:”abbccd”

解释:”abbccd”压缩后为”a1b2c2d1”,比原字符串长度更长。

直接统计

class Solution {
    public String compressString(String S) {
        if (S.length() == 0) { // 空串处理
            return S;
        }
        StringBuffer ans = new StringBuffer();
        int  cnt = 1;
        char ch = S.charAt(0);
        for (int i = 1; i < S.length(); ++i) &#123;
            if (ch == S.charAt(i)) &#123;
                cnt++;
            &#125; else &#123;
                ans.append(ch);
                ans.append(cnt);
                ch = S.charAt(i);
                cnt = 1;
            &#125;
        &#125;
        ans.append(ch);//最后一个还没添加呢
        ans.append(cnt);
        return ans.length() >= S.length() ? S : ans.toString();
    &#125;

// 作者:LeetCode-Solution
// 链接:https://leetcode-cn.com/problems/compress-string-lcci/solution/zi-fu-chuan-ya-suo-by-leetcode-solution/

&#125;

双指针法

class Solution &#123;
    public String compressString(String S) &#123;
        int N = S.length();
        int i = 0;
        StringBuilder sb = new StringBuilder();
        while (i < N) &#123;
            int j = i;
            while (j < N && S.charAt(j) == S.charAt(i)) &#123;
                j++;//第一次i=0,j=0也会执行
            &#125;
            sb.append(S.charAt(i));
            sb.append(j - i);
            i = j;
        &#125;

        String res = sb.toString();
        if (res.length() < S.length()) &#123;
            return res;
        &#125; else &#123;
            return S;
        &#125;
    &#125;
// 作者:nettee
// 链接:https://leetcode-cn.com/problems/compress-string-lcci/solution/shuang-zhi-zhen-fa-qu-lian-xu-zi-fu-cpython-by-net/

&#125;

文章作者:   future
版权声明:   本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 future !
 上一篇
26. 删除排序数组中的重复项 26. 删除排序数组中的重复项
26. 删除排序数组中的重复项难度简单 1860 给定一个排序数组,你需要在**  原地** 删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。 不要使用额外的数组空间,你必须在 **原地  ****修改输入数组  **并
下一篇 
剑指 Offer 28. 对称的二叉树 剑指 Offer 28. 对称的二叉树
剑指 Offer 28. 对称的二叉树难度简单 134 请实现一个函数,用来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样,那么它是对称的。 例如,二叉树  [1,2,2,3,4,4,3] 是对称的。     1    /
  目录