需求:键盘录入一个字符串,要求统计字符串中每个字符串出现的次数
举例:键盘录入"aababcabcdabcde" 在控制台输出"a(5)b(4)c(3)d(2)e(1)"
分析:
我们可以把结果分为几个部分来看:a(5),b(4),c(3),d(2),e(1)
每一个部分可以看成是:字符和字符对应的次数组成
这样的数据,我们可以通过HashMap集合来存储,键是字符,值是字符出现的次数
注意:键是字符,类型应该是Char;值是字符出现的次数,类型应该是Integer
思路:
键盘录入一个字符串
创建HashMap集合,键是Character,值是Integer
遍历字符串得到每一个字符
拿得到的每一个字符作为键到HashMap集合中去找对应的值,看其返回值
如果返回值是null:说明该字符在HashMap集合中不存在,就把该字符作为键,1作为值存储
如果返回值不是null:说明该字符在HashMap集合中存在,把该值加1,然后重写存储该字符和对应的值
遍历HashMap集合,得到键和值,按照要求进行拼接
package com.aynu3;
//需求:键盘录入一个字符串,要求统计字符串中每个字符串出现的次数
//
// 举例:键盘录入"aababcabcdabcde" 在控制台输出"a(5)b(4)c(3)d(2)e(1)"
//思路:
// 键盘录入一个字符串
// 创建HashMap集合,键是Character,值是Integer
// 遍历字符串得到每一个字符
// 拿得到的每一个字符作为键到HashMap集合中去找对应的值,看其返回值
// 如果返回值是null:说明该字符在HashMap集合中不存在,就把该字符作为键,1作为值存储
// 如果返回值不是null:说明该字符在HashMap集合中存在,把该值加1,然后重写存储该字符和对应的值
// 遍历HashMap集合,得到键和值,按照要求进行拼接
import java.util.HashMap;
import java.util.Scanner;
import java.util.Set;
public class HashMapDemo1 {
public static void main(String[] args) {
//键盘录入一个字符串
Scanner sc=new Scanner(System.in);
System.out.println("请输入一个字符串:");
String line = sc.nextLine();
//创建HashMap集合,键是Character,值是Integer
HashMap<Character,Integer> hm=new HashMap<Character, Integer>();
// TreeMap<Character,Integer> hm=new TreeMap<Character, Integer>();
//遍历字符串得到每一个字符
for (int i=0;i<line.length();i++){
char key = line.charAt(i);
// 拿得到的每一个字符作为键到HashMap集合中去找对应的值,看其返回值
Integer value = hm.get(key);
if (value==null){
// 如果返回值是null:说明该字符在HashMap集合中不存在,就把该字符作为键,1作为值存储
hm.put(key,1);
}else {
// 如果返回值不是null:说明该字符在HashMap集合中存在,把该值加1,然后重写存储该字符和对应的值
value++;
hm.put(key,value);
}
}
// 遍历HashMap集合,得到键和值,按照要求进行拼接
StringBuilder sb=new StringBuilder();
Set<Character> keySet = hm.keySet();
for (Character key:keySet){
Integer value = hm.get(key);
sb.append(key).append("(").append(value).append(")");
}
String result = sb.toString();
//输出结果
System.out.println(result);
}
}
请输入一个字符串:
aababcabcdabcde
a(5)b(4)c(3)d(2)e(1)