leetcode.136只出现一次的数字(JAVA)(hashmap)

11 篇文章 0 订阅
4 篇文章 0 订阅

class Solution {
    public int singleNumber(int[] nums) {
        Map<Integer,Integer>counts=new HashMap<Integer, Integer>();
        for(int num:nums)
        {
            if(counts.containsKey(num))
            {
                counts.put(num,2);
            }
            else
                counts.put(num,1);
        }
            
            //counts.put(num,counts.getOrDefault(num,0));
        
        for(int temp:counts.keySet())
        {
            if(counts.get(temp)==1)
                return temp;
        }
        
        return 0;
        
    }
}
public int singleNumber(int[] nums){
	Hashtable<Integer, Integer> table = new Hashtable<Integer, Integer>();
	for (int i = 0; i < nums.length; i++){
		if (table.containsKey(nums[i])){
			table.remove(nums[i]);
		} else {
			table.put(nums[i], 1);
		}
	}
	Set<Integer> keys = table.keySet();
	int answer = -1;
	for (Integer key : keys) {
		answer = key;
	}
	return answer;
}
public int singleNumber(int[] nums) {
    HashSet<Integer> check = new HashSet<Integer>();
    for(int i = 0; i < nums.length; i++)
        if(!check.remove(nums[i]))
            check.add(nums[i]);
    return check.iterator().next();
}
public class Solution {//重要借鉴于
    public int singleNumber(int[] nums) {
    Map<Integer,Integer> map=new HashMap<Integer,Integer>();
    for(int num:nums){
    if(map.containsKey(num)){
        map.put(num,2);
    }else map.put(num,1);
    }
    for(Integer key:map.keySet()){
        if(map.get(key)==1){
            return key;
        }
    }
    return 0;
    }
}

 

  1. 创建特定的hash表:Map<Integer,Integer>counts=new HashMap<Integer, Integer>();

左边的是key右边的是value

  1. Counts.countainsKey(num)——查找是否有关键值为num的映射,存在返回true
  2. Table.remove(k),若存在关键字为k的映射关系,则将其从表中移除
  3. Iterator迭代器:用于遍历集合
  1. 当创建完成指向某个集合或者容器的Iterator对象是,这是的指针其实指向的是第一个元素的上方,即指向一个空
  2. 当调用hasNext方法的时候,只是判断下一个元素的有无,并不移动指针
  3. 当调用next方法的时候,向下移动指针,并且返回指针指向的元素,如果指针指向的内存中没有元素,会报异 常。
  4. remove方法删除的元素是指针指向的元素。如果当前指针指向的内存中没有元素,那么会抛出异常。

返回集合中第一个元素的方法:return check.iterator().next();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值