0219. Contains Duplicate Ii

0219. Contains Duplicate ii #

题目 #

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

思路 #

滑窗+哈希 #

代码 #

滑窗+哈希 #

class Solution {
    public boolean containsNearbyDuplicate(int[] nums, int k) {
        Set<Integer> set = new HashSet<>();
        for (int i = 0; i < nums.length; i++) {
            if (i > k) set.remove(nums[i - k - 1]);
            if (set.contains(nums[i]) == true) return true;
            set.add(nums[i]);
        }
        return false;
    }
}

致谢 #

宫水三叶