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。

相关文章
|
29天前
|
存储 算法 JavaScript
怎么刷算法,leetcode上有哪些经典题目
怎么刷算法,leetcode上有哪些经典题目
13 0
|
1月前
|
算法 Java
[Java·算法·简单] LeetCode 27. 移除元素 详细解读
[Java·算法·简单] LeetCode 27. 移除元素 详细解读
23 1
【移除链表元素】LeetCode第203题讲解
【移除链表元素】LeetCode第203题讲解
|
1月前
|
算法
LeetCode[题解] 1261. 在受污染的二叉树中查找元素
LeetCode[题解] 1261. 在受污染的二叉树中查找元素
16 1
|
1月前
|
算法 Java
[Java·算法·中等] LeetCode15. 三数之和
[Java·算法·中等] LeetCode15. 三数之和
30 0
|
1天前
|
算法 DataX
二叉树(中)+Leetcode每日一题——“数据结构与算法”“剑指Offer55-I. 二叉树的深度”“100.相同的树”“965.单值二叉树”
二叉树(中)+Leetcode每日一题——“数据结构与算法”“剑指Offer55-I. 二叉树的深度”“100.相同的树”“965.单值二叉树”
|
3天前
|
算法
【力扣】169. 多数元素
【力扣】169. 多数元素
|
1月前
|
存储 JavaScript
leetcode82. 删除排序链表中的重复元素 II
leetcode82. 删除排序链表中的重复元素 II
22 0
|
1月前
leetcode83. 删除排序链表中的重复元素
leetcode83. 删除排序链表中的重复元素
10 0
|
1月前
|
算法 搜索推荐
LeetCode刷题---215. 数组中的第K个最大元素(双指针,快速选择)
LeetCode刷题---215. 数组中的第K个最大元素(双指针,快速选择)