2022年01月19日 力扣每日一题

题目

给你一个整数数组 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 <= nums.length <= 105
  • -109 <= nums[i] <= 109
  • 0 <= k <= 105
Related Topics
  • 数组
  • 哈希表
  • 滑动窗口
  • 个人解法

    {% tabs categories%}

    import java.util.HashMap;
    import java.util.Map;
    
    class Solution {
        public boolean containsNearbyDuplicate(int[] nums, int k) {
            if (k <= 0) {
                return false;
            }
            Map<Integer, Integer> map = new HashMap<>();
            for (int i = 0; i < nums.length; i++) {
                if (map.containsKey(nums[i]) && i - map.get(nums[i]) <= k) {
                    return true;
                }
                map.put(nums[i], i);
            }
            return false;
        }
    }
    
    from typing import List
    
    
    class Solution:
        def containsNearbyDuplicate(self, nums: List[int], k: int) -> bool:
            map = {}
            for i, num in enumerate(nums):
                if num in map and i - map[num] <= k:
                    return True
                map[num] = i
            return False
    

    {% endtabs %}