哈希表(存在重复元素)(3)

一.题目

217. 存在重复元素 - 力扣(LeetCode)

二.思路讲解

2.1 思路讲解

看到题目要求找出数组中至少出现两次的元素,我们可能会想到用位运算异或 来找出出现奇数次的数,但这里需要的是至少两次 ,即重复出现的数,且可能有多个重复值,异或就不适用了。因此,我们需要用哈希表 来统计每个元素出现的次数。为什么推荐用哈希表而不是数组呢?因为数组元素的值可能是负数 ,如果用数组模拟哈希表,需要将负数映射到非负下标,这往往需要偏移处理,且可能造成空间浪费;而哈希表可以直接以元素值为键,无论正负都能高效存储和查找,实现简单。

三.代码演示

cpp 复制代码
class Solution {
public:
    bool containsDuplicate(vector<int>& nums) 
    {
        unordered_map<int,int>hash;//前者为元素的值,后者为元素出现的次数
        int n = nums.size();
        for(const auto& x : nums)
        {
            hash[x]++;//进元素
            if(hash[x] > 1)//判断元素是否出现
                return true;
        }    
        return false;
    }
};

四.代码讲解

一、初始化哈希表

为了快速判断数组中是否有重复元素,我们需要记录每个元素出现的次数。这里选择 unordered_map<int, int> 作为哈希表,其中键为数组元素的值,值为该元素当前出现的次数。使用哈希表的原因是数组元素可能为负数或较大整数,无法直接用数组下标映射,而哈希表可以直接以元素值为键,灵活且高效。

二、遍历数组并统计

使用范围 for 循环遍历数组 nums 中的每一个元素 x。对于每个元素,执行以下操作:

  • hash[x] 的值加 1,表示该元素出现了一次。

  • 在每次增加后,立即检查当前元素的出现次数是否大于 1,即 if (hash[x] > 1)。如果大于 1,说明该元素已经出现过至少两次,即找到了重复元素。

三、判断重复并返回

一旦发现某个元素的次数大于 1,立即返回 true,表示数组包含重复元素。如果遍历完整个数组都没有返回,则说明所有元素都只出现一次,最后返回 false

四、关键细节
  • 哈希表的选择unordered_map 基于哈希表实现,插入和查找的平均时间复杂度为 O(1)

  • 边统计边判断:在每次增加计数后立即检查,可以提前结束循环,避免不必要的遍历。

  • 空间复杂度 :最坏情况下,所有元素都不重复,哈希表需要存储 n 个元素,空间复杂度为 O(n)

相关推荐
Yvonne爱编码1 小时前
机器学习---聚类四大算法完整实验教程(层次 / K-Means/GMM/ 谱聚类)
算法·机器学习·聚类
東隅已逝,桑榆非晚1 小时前
C语言内存函数
c语言·开发语言·笔记·算法
深蓝电商API1 小时前
爬虫代理IP智能调度:基于响应速度的实时评分算法
爬虫·算法
Oj92q85H51 小时前
如何在Dev-C++中设置TDM-GCC为默认编译器
java·jvm·c++
汉克老师1 小时前
GESP5级C++考试语法知识(十七、二分算法提高篇(一))
c++·算法·二分算法·gesp5级·gesp五级·二分算法易错点
灵智实验室1 小时前
PX4状态估计技术EKF2详解(五):EKF2 故障检测、重置与鲁棒性——从单实例到多实例仲裁
算法·无人机·px 4
东风破1371 小时前
DM达梦数据库安全、审计功能学习记录
数据库·学习·oracle·dm达梦数据库
programhelp_1 小时前
Roblox Coding OA 面经分享|题量不小,但整体更偏工程思维
人工智能·算法·面试
周末也要写八哥1 小时前
机器学习评价指标之平均概念
人工智能·算法·机器学习
王璐WL1 小时前
【C++进阶】多态,坑很多,面试常考!!!
c++·面试