/**
* 利用集合Map实现
* 键盘输入一串字符串,统计每个字符出现次数
* 如:asdsd a-1 s-2 d-2
*
*/
public static void method(){
Hashtable<Character,Integer> map = new Hashtable<>();
Scanner scan = new Scanner(System.in);
System.out.println("输入一串字符:");
String str = scan.nextLine();
char cs[] = str.toCharArray();
//遍历字符数组
for (char c:cs) {
int value = 1;
if(map.containsKey(c)){
value = map.get(c);
value++;
}
map.put(c,value);
}
int i=0;
for (char c: map.keySet()) {
Integer value = map.get(c);
System.out.println(
String.format("%s-%s",c,map.get(c)));
}
解题思路:将输入的字符串,用str.tocharArray()转换成字符数组,用for或者foreach去字符数组进行遍历,
将字符作为key,字符出现的次数作为value,用map.containsKey(c)判断字符是否在key出现,若出现则对其计数++;
反之则value值为初始值1。最后用foreach输出。