描述
给出1个整形数组nums和1个整数k,是否存在索引i和j,使得nums[i] == nums[j] 且i和j之间的差不超过k
Example 1:
Input: nums = [1,2,3,1], k = 3
Output: true.
Example 2:
Input: nums = [1,0,1,1], k = 1
Output: true
Example 3:
Input: nums = [1,2,3,1,2,3], k = 2
Output: false
解析
考虑用滑动窗口与查找表来解决。
-
设置查找表
record
,用来保存每次遍历时插入的元素,record
的最大长度为k
-
遍历数组
nums
,每次遍历的时候在record
查找是否存在相同的元素,如果存在则返回true
,遍历结束 -
如果此次遍历在
record
未查找到,则将该元素插入到record
中,而后查看record
的长度是否为k + 1
-
如果此时
record
的长度是否为k + 1
,则删减record
的元素,该元素的值为nums[i - k]
-
如果遍历完整个数组
nums
未查找到则返回false
代码
public static boolean containsDuplicate2(int[] n, int k) { if (n == null || n.length < k) { return false; } List<Integer> list = new ArrayList<>(k); for (int i = 0; i < n.length; i++) { if (!list.contains(n[i])) { list.add(n[i]); if (list.size() > k) { list.remove(0); } } else { return true; } } return false; }