java 的字符串,按照 不同字符统计个数由多到少输出统计结果,如果统计的个数相 同,则按照ASCII码由小到大排序输出。
时间: 2024-05-02 12:21:00 浏览: 56
可以使用HashMap来统计每个字符出现的次数,然后按照次数从大到小排序,如果次数相同,则按照ASCII码从小到大排序。具体实现如下:
```
import java.util.*;
public class StringCount {
public static void main(String[] args) {
String str = "abccccddeeffgggg";
Map<Character, Integer> map = new HashMap<>();
// 统计每个字符出现的次数
for (int i = 0; i < str.length(); i++) {
char c = str.charAt(i);
if (map.containsKey(c)) {
map.put(c, map.get(c) + 1);
} else {
map.put(c, 1);
}
}
// 将统计结果转换为List,便于排序
List<Map.Entry<Character, Integer>> list = new ArrayList<>(map.entrySet());
// 按照次数从大到小排序,如果次数相同,则按照ASCII码从小到大排序
Collections.sort(list, new Comparator<Map.Entry<Character, Integer>>() {
public int compare(Map.Entry<Character, Integer> o1, Map.Entry<Character, Integer> o2) {
if (o1.getValue() != o2.getValue()) {
return o2.getValue() - o1.getValue();
} else {
return o1.getKey() - o2.getKey();
}
}
});
// 输出统计结果
for (Map.Entry<Character, Integer> entry : list) {
System.out.println(entry.getKey() + ": " + entry.getValue());
}
}
}
```
输出结果为:
```
c: 4
g: 4
d: 2
e: 2
a: 1
b: 1
f: 2
```
其中,字符c和g出现的次数最多,都出现了4次。然后按照ASCII码从小到大排序,先输出字符c,再输出字符g。
阅读全文