题解 | #压缩字符串(一)#

压缩字符串(一)

https://www.nowcoder.com/practice/c43a0d72d29941c1b65c857d8ac9047e

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param param string字符串
     * @return string字符串
     */
    public String compressString (String param) {
        // write code here
        char[] c = param.toCharArray();
        if(c.length < 2){
            return param;
        }
        StringBuilder sb = new StringBuilder();
        Map<Character, Integer> map = new HashMap<Character, Integer>();
        for (int i = 0; i < c.length; i++) {
            if (map.isEmpty()) {
                map.put(c[i], 1);
            } else if (map.get(c[i]) == null) {
                sb.append(c[i - 1]);
                if (map.get(c[i - 1]) > 1) {
                    sb.append(map.get(c[i - 1]));
                }
                map.clear();
                map.put(c[i], 1);
            } else {
                map.put(c[i], map.get(c[i]) + 1);
            }
        }
        sb.append(c[c.length - 1]);
        if (map.get(c[c.length - 1]) > 1) {
            sb.append(map.get(c[c.length - 1]));
        }
        return sb.toString();
    }
}

全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务