题解 | #压缩牛群编号#

压缩牛群编号

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

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param chars char字符型一维数组
     * @return char字符型一维数组
     */
    public char[] compress (char[] chars) {
        // write code here
        Map<Character, Integer> myMap = new HashMap<>();
        for (int i = 0; i < chars.length; i++) {
            myMap.put(chars[i], myMap.getOrDefault(chars[i], 0) + 1);
        }
        StringBuilder stringBuffer = new StringBuilder();
        for (Map.Entry<Character, Integer> map : myMap.entrySet()) {
            if (map.getValue() > 1) {
                stringBuffer.append(map.getKey());
                stringBuffer.append(map.getValue());
            } else {
                stringBuffer.append(map.getKey());
            }
        }
        return stringBuffer.toString().toCharArray();
    }

}

本题所用编程语言是java,可以考虑用栈也可以考虑用哈希表统计每个字符出现的次数

全部评论

相关推荐

不愿透露姓名的神秘牛友
09-17 14:26
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
08-20 19:41
那一天的Java_J...:简历完全流水账,学生思维很严重,还有很大的优化空间,可以多看看牛客的简历。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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