题目:找出出现一次的两个数字
实现思路:
初始化一个空的HashMap,用于存储每个数字及其对应的出现次数。
遍历整数数组中的每个数字(这里用for-each循环实现)。
如果这个数字已经在HashMap中(即该数字已经出现过),那么就将该数字对应的值(出现次数)加1。
如果这个数字不在HashMap中,那么就在HashMap中添加这个数字,并将其对应的值设为1(表示第一次出现)。
遍历HashMap中的每个键值对(这里也用for-each循环实现)。
检查每个键值对的值(即出现次数)。如果值为1,那么就输出这个数字及其出现次数,表示这个数字只出现了一次。
package com.ztt.Demo02;
import java.util.HashMap;
import java.util.TreeMap;
import java.util.Map.Entry;
import java.util.Set;
public class demo17 {
public static void main(String[] args) {
//找出出现一次的两个数字
int[] ns= {1,2,3,4,5,5,3,2,1,7};
HashMap<Integer, Integer> map = new HashMap<Integer, Integer>();
// 统计每个数字的出现次数
for (int n : ns) {
if(map.containsKey(n)) {
//该数字已经存在,出现的次数+1
map.put(n, map.get(n)+1);
}else {
//该数字不存在,出现的次数=1
map.put(n, 1);
}
}
Set<Entry<Integer,Integer>> entrySet=map.entrySet();
for (Entry<Integer, Integer> entry : map.entrySet()) {
if (entry.getValue() == 1) {
System.out.println("数字 " + entry.getKey() + " 出现了一次");
}
}
}
}
运行结果:
数字 4 出现了一次
数字 7 出现了一次