哈希表-219.存在重复元素II-力扣(LeetCode)

一、题目解析

1、i!=j

2、nums[i] == nums[j]且abs(i-j)<=k

二、算法原理

解法:哈希表

与该题解法类似哈希表-1.两数之和-力扣(LeetCode)-CSDN博客,只不过多了一个下标差的判断。这里有一个小细节不容忽视,当哈希表中已存在查询元素时,在下标差比较后,不满足<=k,此时是否覆盖哈希表中的元素,更新下标呢?结果是肯定的,为了满足<=k的条件,肯定是越近的越好,所以离得远的可以直接覆盖

三、代码示例

cpp 复制代码
class Solution {
public:
    bool containsNearbyDuplicate(vector<int>& nums, int k)
    {
        unordered_map<int,int> hash;
        for(int i = 0;i<nums.size();i++)
        {
            if(hash.count(nums[i]))
            {
                if(abs(hash[nums[i]]-i)<=k)
                    return true;
            }
            hash[nums[i]] = i;
        }
        return false;
    }
};

看到最后,如果对您有所帮助,还请点赞、收藏和关注一键三连,感谢您的观看,我们下期再见!

相关推荐
ohyeah1 天前
栈:那个“先进后出”的小可爱,其实超好用!
前端·数据结构
自由生长20241 天前
为什么C++项目偏爱.cxx扩展名:从MongoDB驱动说起
c++
CSDN_RTKLIB1 天前
【GNU、GCC、g++、MinGW、MSVC】上
c++·gnu
b***74881 天前
C++在系统中的内存对齐
开发语言·c++
散峰而望1 天前
C++数组(三)(算法竞赛)
开发语言·c++·算法·github
4***14901 天前
C++在系统中的编译优化
开发语言·c++
mit6.8241 天前
[HomeKey] 握手协议 | NFC协议处理器
c++
oioihoii1 天前
C++程序执行起点不是main:颠覆你认知的真相
开发语言·c++
hetao17338371 天前
2025-11-25~26 hetao1733837的刷题记录
c++·算法
历程里程碑1 天前
各种排序法大全
c语言·数据结构·笔记·算法·排序算法