import java.util.HashMap;
import java.util.Scanner;
/*
1. 取一个字符串对象
2. 创建一个Map集合,键代表字符,值代表次数。
3. 遍历字符串得到每个字符。
4. 判断Map中是否有该键。
5. 如果没有,第一次出现,存储次数为1;如果有,则说明已经出现过,获取到对应的值进行++,再次存储。
6. 打印最终结果
*/
public class MapTest {
public static void main(String[] args) {
System.out.println("请输入一个字符串");
String line =new Scanner(System.in).nextLine();
//定义 每个字符出现次数的方法
findChar(line);
}
private static void findChar(String line) {
//1.创建一个集合 存储 字符以及其出现的次数
HashMap<Character,Integer> map=new HashMap<Character,Integer>();
//遍历字符串
for(int i=0;i<line.length();i++){
char c=line.charAt(i);
//判断该字符是否在键集中
if(!map.containsKey(c)){
map.put(c,1);
}else {
//先获取之前的次数
Integer count=map.get(c);
map.put(c,++count);
}
}
System.out.println(map);
}
}
这里使用map双链集合,
findChar();是我定义的方法
这里你也可以取其他名字这个没有区别
为什么我选择双路,我们可以用键和值来进行分别对应字符和数量,
charAt();获取
HashMap<K,V>:存储数据采用的哈希表结构,元素的存取顺序不能保证一致。由于要保证键的唯一、不重复,需要重写键的hashCode()方法、equals()方法。