137.只出现一次的数字II

137. 只出现一次的数字 II - 力扣(LeetCode)

给你一个整数数组 nums ,除某个元素仅出现 一次 外,其余每个元素都恰出现 三次 。请你找出并返回那个只出现了一次的元素。

你必须设计并实现线性时间复杂度的算法且使用常数级空间来解决此问题。

示例 1:

输入:nums = [2,2,3,2]
输出:3

示例 2:

输入:nums = [0,1,0,1,0,1,99]
输出:99

提示:

  • 1 <= nums.length <= 3 * 104
  • -231 <= nums[i] <= 231 - 1
  • nums 中,除某个元素仅出现 一次 外,其余每个元素都恰出现 三次

思路

可以运用Map中特殊的一对一属性来写,也就是数字对出现的次数,然后再找出次数为0的value,输出对应的Key;

entrySet:只要是能运用getKey()和getValue(),可以分别获得键与值;

遍历Map的四种方式

完整代码

class Solution {
    public int singleNumber(int[] nums) {
      Map map = new HashMap<>();

        for (int num : nums) {
            map.put(num, map.getOrDefault(num, 0) + 1);
        }

        int ans = 0;
        for (Map.Entry entry : map.entrySet()) {
            int num = entry.getKey()
            int  count = entry.getValue();
            if (count == 1) {
                ans = num;
                break;
            }
        }
              return ans;
        
    }
}

你可能感兴趣的:(算法,数据结构,leetcode)