题目:
给定一个字符串,请将字符串里的字符按照出现的频率降序排列。
示例 1:
输入:
"tree"输出:
"eert"解释:
'e'出现两次,'r'和't'都只出现一次。
因此'e'必须出现在'r'和't'之前。此外,"eetr"也是一个有效的答案。
示例 2:输入:
"cccaaa"输出:
"cccaaa"解释:
'c'和'a'都出现三次。此外,"aaaccc"也是有效的答案。
注意"cacaca"是不正确的,因为相同的字母必须放在一起。
示例 3:输入:
"Aabb"输出:
"bbAa"解释:
此外,"bbaA"也是一个有效的答案,但"Aabb"是不正确的。
注意'A'和'a'被认为是两种不同的字符。来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/sort-characters-by-frequency
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解答:
class Solution {
public String frequencySort(String s) {
Map<Character,Integer> fre = new HashMap();
//计算每个字符的频次,这里也可以用数组自己生成一个map
for(char c:s.toCharArray()){
fre.put(c,fre.getOrDefault(c,0)+1);
}
//桶排序
List<Character>[] bucket = new ArrayList[s.length()+1];
for(char c:fre.keySet()){
int f=fre.get(c);
if(bucket[f]==null)
bucket[f]=new ArrayList();
bucket[f].add(c);
}
StringBuilder str = new StringBuilder();
for(int i=bucket.length-1;i>=0;i--){
if(bucket[i]==null)
continue;
for(char c:bucket[i]){
for(int j=0;j<i;j++){
str.append(c);
}
}
}
return str.toString();
}
}
感觉和频次有关的问题,都可以尝试用桶排序来求解。
比如这一题 前 K 个高频元素