利用集合实现获取字符串中每个字母出现的次数并使用StringBuffer类 以要求的格式输出
public class Test {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.println("请输入一个字符串");
String str = scanner.next();
char[] a = str.toCharArray();
Map<Character, Integer> map = new HashMap<>();
for(int i = 0 ;i < a.length;i++) {
if(map.containsKey(a[i])) {
map.put(a[i], map.get(a[i])+ 1);
}else {
map.put(a[i], 1);
}
}
//System.out.println(map);
StringBuffer sb = new StringBuffer();
Set<java.util.Map.Entry<Character,Integer>> entrySet = map.entrySet();
for(java.util.Map.Entry<Character,Integer> entry : entrySet) {
sb.append(entry.getKey()).append("(").append(entry.getValue()).append(")");
}
System.out.println(sb);
}
}
测试结果如下
请输入一个字符串
aabbbcdd
a(2)b(3)c(1)d(2)