Leetcode5-在长度2N的数组中找出重复N次的元素(961)

1、题目

给你一个整数数组 nums ,该数组具有以下属性:

nums.length == 2 * n.
nums 包含 n + 1 个 不同的 元素
nums 中恰有一个元素重复 n 次
找出并返回重复了 n 次的那个元素。

示例 1:

输入:nums = [1,2,3,3]
输出:3
示例 2:

输入:nums = [2,1,2,5,3,2]
输出:2
示例 3:

输入:nums = [5,1,5,2,5,3,5,4]
输出:5

2、解

通过哈希表进行存储遍历,记录每个元素出现次数,当出现次数刚好为n时停止遍历输出该元素。

int repeatedNTimes(vector<int> &nums)
    {
   
    unordered_map<int, int> cnt;
    int goalNumber = 0;
    for(int num : nums)
    {
   
        cnt[num] ++;
        if(nums.size() /2 == cnt[num])
        {
   
            goalNumber = num;
            break;
        }
    }
    return goalNumber;
    }

另解

记重复 n次的元素为 x。由于数组 nums 中有 n+1 个不同的元素,而其长度为 2n,那么数组中剩余的元素均只出现了一次。也就是说,我们只需要找到重复出现的元素即为答案。

因此我们可以对数组进行一次遍历,并使用哈希集合存储已经出现过的元素。如果遍历到了哈希集合中的元素,那么返回该元素作为答案。

class Solution {
   
public:
    int repeatedNTimes(vector<int>& nums) {
   
        unordered_set<int> found;
        for (int num: nums) {
   
            if (found.count(num)) {
   
                return num;
            }
            found.insert(num);
        }
        // 不可能的情况
        return -1;
    }
};

最近更新

  1. TCP协议是安全的吗?

    2024-01-02 14:56:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-02 14:56:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-02 14:56:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-02 14:56:03       18 阅读

热门阅读

  1. (vue)怎么监听表单里边的数据

    2024-01-02 14:56:03       42 阅读
  2. Git - 托管平台

    2024-01-02 14:56:03       37 阅读
  3. Spring ProxyFactoryBean

    2024-01-02 14:56:03       39 阅读
  4. Halcon 3D相关算子(一)

    2024-01-02 14:56:03       32 阅读
  5. HarmonyOS UI框架简介

    2024-01-02 14:56:03       45 阅读
  6. K8S学习指南(58)-K8S核心组件Kubelet简介

    2024-01-02 14:56:03       36 阅读
  7. windows系统lib文件和dll文件的区别

    2024-01-02 14:56:03       33 阅读
  8. WEB前端demo4

    2024-01-02 14:56:03       39 阅读
  9. linux时间同步

    2024-01-02 14:56:03       36 阅读
  10. 探索 PyTorch 中的 torch.nn 模块**(1)

    2024-01-02 14:56:03       38 阅读