统计一个字符串中,哪个字符出现的次数最多,我的实战中,字符串是以逗号拼接起来的字符串,方法也只适用于这类字符串,因为计算重复字符出现的次数,本质上还是以逗号分隔开,循环进行统计,代码如下:
private Map.Entry<String, Integer> extracted(String unit) {
Map<String, Integer> map = new HashMap<>();
String[] split1 = unit.split(",");
for (String element : split1) {
if (StringUtils.isNotBlank(element)) {
// 如果元素已经存在于 HashMap 中,则将其出现次数加 1
if (map.containsKey(element)) {
map.put(element, map.get(element) + 1);
} else {
// 否则,将元素和出现次数 1 存入 HashMap
map.put(element, 1);
}
}
}
// 获取 HashMap 中出现次数最多的元素
Map.Entry<String, Integer> maxEntry = null;
for (Map.Entry<String, Integer> entry : map.entrySet()) {
if (maxEntry == null || entry.getValue() > maxEntry.getValue()) {
maxEntry = entry;
}
}
return maxEntry;
}
返回一个map结构的数据,getKey就能获取到具体哪个字符出现的次数最多,getValue获取能获取到次数。