用treeMap集合来实现该案例
想法:
1.键盘录入一个字符串
2.创建TreeMap集合,键是Character,值是Integer
3.遍历字符串,得到每一个字符
4.拿到每一个字符作为键HashMap集合中去找对应的值,看其返回值
注意:1.如果返回值是null:说明该字符在TreeMap集合中不存在,就把该字符作为键,1作为值存储。
2.如果返回值不是null:说明该字符在TreeMap集合中存在,把该值加一,然后重新存储该字符和对应的值
5.遍历TreeMap集合,得到键和值,按照要求进行拼接
6.输出结果
package test06;
import java.util.*;
public class HashMapDemo {
public static void main(String[] args) {
//键盘录入一个字符串
Scanner sc=new Scanner(System.in);
System.out.println("请输入一串字符串:");
String line=sc.nextLine();
// HashMap<Character,Integer> map=new HashMap<Character,Integer>();
//创建TreeMap集合,键是Character,值是Integer
TreeMap<Character,Integer> map=new TreeMap<Character,Integer>();
//遍历字符串,得到每一个字符
for (int i=0;i<line.length();i++){
char key=line.charAt(i);
//拿到每一个字符作为键到TreeMap集合中去找对应的值,看其返回值
Integer value=map.get(key);
//如果返回值是null,说明该字符在TreeMap集合中不存在,就把该字符串作为键,1作为值存储
if (value==null){
map.put(key,1);
}else {
//如果返回值不是null,说明该字符在TreeMap集合中存在,把该值加一,然后重新存储该字符和对应的值
value++;
map.put(key,value);
}
}
StringBuilder sb=new StringBuilder();
Set<Character> keyset=map.keySet();
//遍历TreeMap集合,得到键和值,按照要求进行拼接
for (Character key:keyset){
Integer value=map.get(key);
sb.append(key).append("(").append(value).append(")");
}
//调用toString方法,从StringBuilder转为String类型输出
String result=sb.toString();
System.out.println(result);
}
}