LeetCode 219.存在重复元素 II

目录

题目:

题目描述:

题目链接:

思路:

核心思路:

思路详解:

代码:

C++代码:

Java代码:


题目:

题目描述:

题目链接:

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

思路:

核心思路:

哈希表(Map)

思路详解:

Map存的是键值对,这题键存的是数组中的元素值,值存的是该元素值的最新索引(下标),时间复杂度为O(n)。遍历整个数组把每一个元素和它的索引存入Map,每次存入一个元素先调用containsKey判断Map中是否存在相同的键值,如果存在再判断这个相同元素不同索引差值的绝对值是否<=k,只要存在一对满足要求就可以马上return true;退出。如果不满足就把这个键值对存入Map(该键不存在就是新存入的键值对,键已经存在就是更新最新索引)。如果已经遍历完数组全部元素都没有满足要求的,就返回false

代码:

C++代码:

复制代码
class Solution {
public:
    bool containsNearbyDuplicate(vector<int>& nums, int k) {
        unordered_map<int,int> mp;
        for(int i=0;i<nums.size();i++)
        {
            //由于unordered_map不允许存储具有重复键的元素,因此count函数基本上用于
            //检查unordered_map中是否存在带有给定键的元素
            if(mp.count(nums[i])&&abs(i+1-mp[nums[i]]<=k))
            {
                return true;
            }
            mp[nums[i]]=i+1;
        }
        return false;
    }
};

Java代码:

复制代码
class Solution {
    public boolean containsNearbyDuplicate(int[] nums, int k) {
        HashMap<Integer,Integer> hm = new HashMap<>();
        for(int i=0;i<nums.length;i++)
        {
            if(hm.containsKey(nums[i])&&Math.abs(i-hm.get(nums[i]))<=k)
            {
                return true;
            }
            hm.put(nums[i],i);
        }
        return false;
    }
}
相关推荐
aini_lovee4 分钟前
FMCW雷达测速测距系统(锯齿波 + CFAR检测)
算法
qq_297574678 分钟前
设计模式系列文章(基础篇第 11 篇):模板方法模式——定义算法骨架,实现代码复用与流程统一
算法·设计模式·模板方法模式
lqqjuly15 分钟前
知识蒸馏:理论、算法与可运行实现
人工智能·深度学习·算法
水上冰石24 分钟前
comfui的sd1.5模型,有多少采样算法,详解每一个采样算法
人工智能·算法
黎阳之光42 分钟前
视频孪生+空天地水工融合,黎阳之光构建智慧水利监测新范式
大数据·人工智能·物联网·算法·安全
凯瑟琳.奥古斯特1 小时前
子查询原理与实战案例解析
开发语言·数据库·职场和发展·数据库开发
cheems95271 小时前
[算法手记] 贪心 爬楼梯问题
算法·贪心算法
KaMeidebaby1 小时前
卡梅德生物技术快报|酵母双杂交 cDNA 文库构建与蛋白互作筛选流程
服务器·前端·数据库·人工智能·算法
圣保罗的大教堂1 小时前
leetcode 3300. 替换为数位和以后的最小元素 简单
leetcode
sheeta19981 小时前
LeetCode 每日一题笔记 日期:2026.05.27 题目:3121. 统计特殊字母的数量 II
笔记·算法·leetcode