219. 存在重复元素 II【 力扣(LeetCode) 】

一、题目描述

给你一个整数数组 nums 和一个整数 k ,判断数组中是否存在两个 不同的索引 i 和 j ,满足 nums[i] == nums[j] 且 abs(i - j) <= k 。如果存在,返回 true ;否则,返回 false 。

二、测试用例

示例 1:

cpp 复制代码
输入:nums = [1,2,3,1], k = 3
输出:true

示例 2:

cpp 复制代码
输入:nums = [1,0,1,1], k = 1
输出:true

示例 3:

cpp 复制代码
输入:nums = [1,2,3,1,2,3], k = 2
输出:false

提示:

cpp 复制代码
1 <= nums.length <= 105
-109 <= nums[i] <= 109
0 <= k <= 105

三、解题思路

  1. 基本思路:
      每遇到一个数,就去判断以前是否遇到过,遇到过在判断下标相差是否小于等于 k
  2. 具体思路:
      遍历序列,判断当前数是否存在 map 中,存在则判断下标是否 <= k ,是则返回 true ;否则,则把当前数和下标存放到 map 中。

四、参考代码

时间复杂度: O ( n ) \Omicron(n) O(n)

空间复杂度: O ( n ) \Omicron(n) O(n) 【也可以优化到 O ( k ) \Omicron(k) O(k) ,只要改为 map 的大小超过 k 就开始删除元素】

cpp 复制代码
class Solution {
public:
    bool containsNearbyDuplicate(vector<int>& nums, int k) {
        int n=nums.size();
        map<int,int> m;

        for(int i=0;i<n;i++){
            if(m.count(nums[i])==1&&i-m[nums[i]]<=k){
                    return true;
            }
            m[nums[i]]=i;
        }

        return false;
    }
};
相关推荐
熊文豪3 分钟前
探索CANN ops-nn:高性能哈希算子技术解读
算法·哈希算法·cann
熊猫_豆豆20 分钟前
YOLOP车道检测
人工智能·python·算法
艾莉丝努力练剑34 分钟前
【Linux:文件】Ext系列文件系统(初阶)
大数据·linux·运维·服务器·c++·人工智能·算法
Once_day1 小时前
C++之《程序员自我修养》读书总结(1)
c语言·开发语言·c++·程序员自我修养
Trouvaille ~1 小时前
【Linux】TCP Socket编程实战(一):API详解与单连接Echo Server
linux·运维·服务器·网络·c++·tcp/ip·socket
偷吃的耗子1 小时前
【CNN算法理解】:CNN平移不变性详解:数学原理与实例
人工智能·算法·cnn
坚果派·白晓明1 小时前
在鸿蒙设备上快速验证由lycium工具快速交叉编译的C/C++三方库
c语言·c++·harmonyos·鸿蒙·编程语言·openharmony·三方库
小镇敲码人1 小时前
深入剖析华为CANN框架下的Ops-CV仓库:从入门到实战指南
c++·python·华为·cann
dazzle2 小时前
机器学习算法原理与实践-入门(三):使用数学方法实现KNN
人工智能·算法·机器学习
那个村的李富贵2 小时前
智能炼金术:CANN加速的新材料AI设计系统
人工智能·算法·aigc·cann