一个整型数组里除了两个数字之外,其他的数字都出现了偶数次。请写程序找出这两个只出现一次的数字。

package arraydemo;

import java.util.HashMap;

/** 
 * @author wyl
 * @time 2018年8月21日下午2:44:24
 * 一个整型数组里除了俩个数字之外,其他的数字都出现了偶数次,
 * 找出两个只出现一次的数字。
 * 
 * 向hashmap中添加数组,若存在,则删除,若不存在,则添加
 */
public class Solution3 {
	public static void main(String[] args) {
		int[] a={6,3,4,5,7,5,4,3};
		new Solution3().FindNumsAppearOnce(a);
	}
	 public void FindNumsAppearOnce(int [] array) {
	        HashMap<Integer, Integer> map=new HashMap<>();
	        for(int i=0;i<array.length;i++){//若存在,则删除,若不存在,则添加
	        	int tmp=array[i];
	        	if (map.containsKey(tmp)) {
					map.remove(tmp);
				}else {
					map.put(tmp, 1);
				}
	        }
	        for(Integer e:map.keySet()){//返回所有的key值
	        	System.out.println(e);
	        }
	 }
}

Map集合的四种遍历方式

 1 import java.util.HashMap;
 2 import java.util.Iterator;
 3 import java.util.Map;
 4 
 5 public class TestMap {
 6     public static void main(String[] args) {
 7         Map<Integer, String> map = new HashMap<Integer, String>();
 8         map.put(1, "a");
 9         map.put(2, "b");
10         map.put(3, "ab");
11         map.put(4, "ab");
12         map.put(4, "ab");// 和上面相同 , 会自己筛选
13         System.out.println(map.size());
14         // 第一种:
15         /*
16          * Set<Integer> set = map.keySet(); //得到所有key的集合
17          * 
18          * for (Integer in : set) { String str = map.get(in);
19          * System.out.println(in + "     " + str); }
20          */
21         System.out.println("第一种:通过Map.keySet遍历key和value:");
22         for (Integer in : map.keySet()) {
23             //map.keySet()返回的是所有key的值
24             String str = map.get(in);//得到每个key多对用value的值
25             System.out.println(in + "     " + str);
26         }
27         // 第二种:
28         System.out.println("第二种:通过Map.entrySet使用iterator遍历key和value:");
29         Iterator<Map.Entry<Integer, String>> it = map.entrySet().iterator();
30         while (it.hasNext()) {
31              Map.Entry<Integer, String> entry = it.next();
32                System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
33         }
34         // 第三种:推荐,尤其是容量大时
35         System.out.println("第三种:通过Map.entrySet遍历key和value");
36         for (Map.Entry<Integer, String> entry : map.entrySet()) {
37             //Map.entry<Integer,String> 映射项(键-值对)  有几个方法:用上面的名字entry
38             //entry.getKey() ;entry.getValue(); entry.setValue();
39             //map.entrySet()  返回此映射中包含的映射关系的 Set视图。
40             System.out.println("key= " + entry.getKey() + " and value= "
41                     + entry.getValue());
42         }
43         // 第四种:
44         System.out.println("第四种:通过Map.values()遍历所有的value,但不能遍历key");
45         for (String v : map.values()) {
46             System.out.println("value= " + v);
47         }
48     }
49 }

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Baymax_wyl

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值