题目:
给定[“a”,”b”,”a”,”b”,”c”,”a”,”b”,”c”,”b”]字符串数组,然后使用Map的key来保存数组的字符串元素,value保存该字符串元素出现的次数
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.SynchronousQueue;
public class HashMapTest {
public static void main(String[] args) {
String str = new String("1,2,3,1,1,4,5,4,6,1,2,3,4,8") ;
HashMap<Character, Integer> hm = new HashMap<>() ;
for (int i= 0;i < str.length();i++) {
if (! hm.containsKey(str.charAt(i))) {
hm.put(str.charAt(i), 1) ;
} else {
hm.put(str.charAt(i), hm.get(str.charAt(i))+1) ;
}
}
System.out.println(hm) ;
}
}
Ps:写一下我在写这题遇到的几个小问题,也确实比较脑残
1. for (int i= 0;i < str.length();i++)
在写这块的时候习惯性的写成i < =str.length()
没注意字符串下标是从0开始的 所以一直报错
2.hm.put(str.charAt(i), hm.get(str.charAt(i))+1) ;
在这这块代码的时候想不用泛型,但是不使用泛型 Map内的 Value 是Obj形的,所以一个对象+1 这种语法错误,也是比较脑残的问题