zoukankan      html  css  js  c++  java
  • 面试金典——字符串压缩

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

    示例1:
    输入:"aabcccccaaa"
    输出:"a2b1c5a3"
    示例2:
    输入:"abbccd"
    输出:"abbccd"
    解释:"abbccd"压缩后为"a1b2c2d1",比原字符串长度更长。

    提示:
    字符串长度在[0, 50000]范围内。

    A:
    注意最后的字符处理就行了。

        public String compressString(String S) {
            if (S.length() == 0)
                return S;
            StringBuilder string = new StringBuilder();
            int count = 1;
            for (int i = 1; i <= S.length(); i++) {
                if (i != S.length() && S.charAt(i) == S.charAt(i - 1))
                    count++;
                else {
                    string.append(S.charAt(i - 1));
                    string.append(count);
                    count = 1;
                }
            }
            return string.length() < S.length() ? string.toString() : S;
        }
    
  • 相关阅读:
    进程同步和死锁;事务、悲观锁、乐观锁、表锁、行锁
    快速排序
    oracle索引分类
    数据结构
    MySQL视图
    sql优化的方法
    MySQL索引
    转:关于ROWNUM的使用
    转载:mybatis踩坑之——foreach循环嵌套if判断
    Spring 注意事项
  • 原文地址:https://www.cnblogs.com/xym4869/p/12979128.html
Copyright © 2011-2022 走看看