HashTable集合和练习题_计算一个字符串中每一个字符出现的次数

2023-05-13,,

HashTable集合

/**
* java.util.Hashtable<K,V>集合 implement Map<K,V>接口
* Hashtable:底层也是一个哈希表,是一个线程安全的集合,是单线程集合,速度慢
* HashMap:底层是一个哈希表,是一个线程不安全的集合,是多线程的集合,速度快
*
* HashMap集合:可以存储null值null键
* Hashtable集合:不可以存储null值null键
*
* Hashtable集合和Vector集合一样,在jdk1.2版本后被更先进的集合取代了
* Hashtable的子类properties依然活跃在历史舞台
* properties集合是唯一一个和Io流相结合的集合
*/
public static void main(String[] args) {
HashMap<String, String> hashMap = new HashMap<>();
hashMap.put(null,"a");
hashMap.put("b",null);
System.out.println(hashMap);//{null=a, b=null} Hashtable<String, String> hashtable = new Hashtable<>();
hashtable.put(null,"c");//NullPointerException
hashtable.put("d",null);//NullPointerException System.out.println(hashtable);
}

练习题_计算一个字符串中每一个字符出现的次数

使用Scanner获取用户输入的一个字符串

例如:

aaabbbbcca

a 4

b 4

c 2

不能重复 可以重复

字符 统计个数

HashMap<Character,Integer>

遍历字符串获取每一个字符

1.String类的方法toCharArray。把字符串转换为一个字符数组,遍历数组

2.String类的方法lenth()+charAt(索引)

使用Map集合中的方法判断渠道的字符是否存储在集合中

1.使用Map集合中的方法contrinsKey(截取到的字符)返回的是布尔类型

true:存在字符

通过字符获取value统计个数

把value++

再把新的value存储到Map集合中

false字符不存在

把字符作为key1作为value存储到Map集合中

2.使用Map集合的get(Key)

返回null,key不存在

不是null,可以存在

代码:

public static void main(String[] args) {
Scanner in = new Scanner(System.in);
System.out.println("请输入一些字符");
String str = in.next(); HashMap<Character, Integer> map = new HashMap<>(); for (char c :str.toCharArray()){
if (map.containsKey(c)){
Integer integer = map.get(c);
integer++;
map.put(c,integer);
}else{
map.put(c,1);
}
}
map.forEach((character, integer) -> System.out.println(character+"-"+integer));
}

HashTable集合和练习题_计算一个字符串中每一个字符出现的次数的相关教程结束。

《HashTable集合和练习题_计算一个字符串中每一个字符出现的次数.doc》

下载本文的Word格式文档,以方便收藏与打印。