leetcode算法219.存在重复元素 II

简介: 给你一个整数数组 nums 和一个整数 k ,如何判断数组中是否存在两个不同的索引 i 和 j ,满足 nums[i] == nums[j] 且 abs(i - j) <= k ?本文带大家解决这个问题。

一、leetcode算法



1、存在重复元素 II


1.1、题目


给你一个整数数组 nums 和一个整数 k ,判断数组中是否存在两个不同的索引 i 和 j ,满足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


1.2、思路


思路一:此题我们可以使用hash表来解决问题,这道题有一个对应关系,就是数组的值和数组的下标有对应的关系,所以我们使用map来存储数组的值和对应的下标来使用。


1.3、答案


11.png


class Solution {
    public boolean containsNearbyDuplicate(int[] nums, int k) {
        Map<Integer,Integer> map = new HashMap<Integer,Integer>();
        int length = nums.length;
        for(int i = 0; i < length; i++){
            int num = nums[i];
            //如果存在值相同,并且下标相减小于等于k
            if(map.containsKey(num) && i-map.get(num) <= k){
                return true;
            }
            //将值和下标对应存入map中
            map.put(num,i);
        }
        return false;
    }
}


复杂度分析


时间复杂度:O(n),其中 n 是数组 nums 的长度。需要遍历数组一次,对于每个元素,哈希表的操作时间都是 O(1)。


空间复杂度:O(n),其中 n 是数组 nums 的长度。需要使用哈希表记录每个元素的最大下标,哈希表中的元素个数不会超过 n。

相关文章
|
4月前
【力扣】-- 移除链表元素
【力扣】-- 移除链表元素
55 1
|
4月前
|
存储 算法 Java
解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用
在Java中,Set接口以其独特的“无重复”特性脱颖而出。本文通过解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用。
88 3
|
4月前
【LeetCode 27】347.前k个高频元素
【LeetCode 27】347.前k个高频元素
55 0
|
4月前
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
61 0
|
3月前
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
|
4月前
|
存储 算法 Java
Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定数据结构和算法确保元素唯一性
Java Set因其“无重复”特性在集合框架中独树一帜。本文解析了Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定数据结构和算法确保元素唯一性,并提供了最佳实践建议,包括选择合适的Set实现类和正确实现自定义对象的hashCode()与equals()方法。
97 4
|
4月前
|
算法
每日一道算法题(Leetcode 20)
每日一道算法题(Leetcode 20)
51 2
|
6月前
|
算法
测试工程师的技能升级:LeetCode算法挑战与职业成长
这篇文章通过作者亲身体验LeetCode算法题的过程,探讨了测试工程师学习算法的重要性,并强调了算法技能对于测试职业成长的必要性。
105 1
测试工程师的技能升级:LeetCode算法挑战与职业成长
|
4月前
【LeetCode 06】203.移除链表元素
【LeetCode 06】203.移除链表元素
43 0
|
4月前
【LeetCode-每日一题】移除元素
【LeetCode-每日一题】移除元素
42 0