题解 | #压缩字符串(一)#
压缩字符串(一)
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(); } }