[LeetCode] 219. 存在重复元素 II

题目描述:

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

示例 1:

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

示例 2:

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

示例 3:

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

题目链接:

. - 力扣(LeetCode)

解题主要思想:

其实这道题跟 "两数之和" 有点像,但需要注意的是,题目说的是<= k,因此我们需要尽可能地缩小i和j的距离,但如果是>= k,那我们就需要尽可能地增大i和j的距离,解决办法就是只记录第一次发现nums[i]时的下标。

两数之和链接:
[LeetCode] 1. 两数之和-CSDN博客

解题代码:

cpp 复制代码
class Solution {
public:
    bool containsNearbyDuplicate(vector<int>& nums, int k) {
        unordered_map<int, int> map;
        for(int i = 0; i < nums.size(); ++i) {
            if (map.count(nums[i])) {
                if ((i-map[nums[i]]) <= k) return true;
            }
            map[nums[i]] = i;  // 如果是>= k,那么就需要加上在这行代码最前面加上else
        }
        return false;
    }
};
相关推荐
Trouvaille ~1 小时前
【LInux】进程程序替换与shell实现:从fork到exec的完整闭环
linux·运维·c语言·c++·ssh·进程替换·基础入门
YXWik61 小时前
Linux安装Whisper(C++版)音频解析文本
linux·c++·whisper
Lv11770081 小时前
Visual Studio 中的 ArrayList数组 和 List数组
数据结构·笔记·c#·list·visual studio
王璐WL1 小时前
【数据结构】栈和队列及相关算法题
数据结构·算法
麒qiqi1 小时前
Linux 线程(POSIX)核心教程
linux·算法
Zhi.C.Yue1 小时前
React 的桶算法详解
前端·算法·react.js
小热茶1 小时前
浮点数计算专题【五、 IEEE 754 浮点乘法算法详解---基于RISCV的FP32乘法指令在五级流水线的运行分析与SystemC实现】
人工智能·嵌入式硬件·算法·systemc
Giser探索家1 小时前
卫星遥感数据核心参数解析:空间分辨率与时间分辨率
大数据·图像处理·人工智能·深度学习·算法·计算机视觉
_OP_CHEN1 小时前
【从零开始的Qt开发指南】(十)Qt 常用控件之输入类控件全攻略:7 大控件从入门到实战,覆盖所有输入场景
开发语言·c++·qt·前端开发·qt常用控件·gui图形化界面·qt输入类控件
q_30238195561 小时前
破局路侧感知困境:毫米波雷达+相机融合算法如何重塑智能交通
数码相机·算法