leet-code/src/main/java/leetcode/editor/cn/ContainsDuplicateIi.java

53 lines
1.4 KiB
Java
Raw Normal View History

2021-09-01 12:42:39 +08:00
//给定一个整数数组和一个整数 k判断数组中是否存在两个不同的索引 i 和 j使得 nums [i] = nums [j],并且 i 和 j 的差的 绝对值
// 至多为 k。
//
//
//
// 示例 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
// Related Topics 数组 哈希表 滑动窗口 👍 306 👎 0
package leetcode.editor.cn;
2022-01-19 11:08:55 +08:00
import java.util.HashMap;
import java.util.Map;
2021-09-01 12:42:39 +08:00
//219:存在重复元素 II
class ContainsDuplicateIi {
public static void main(String[] args) {
//测试代码
Solution solution = new ContainsDuplicateIi().new Solution();
}
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
public boolean containsNearbyDuplicate(int[] nums, int k) {
if (k <= 0) {
return false;
}
2022-01-19 11:08:55 +08:00
Map<Integer, Integer> map = new HashMap<>();
2021-09-01 12:42:39 +08:00
for (int i = 0; i < nums.length; i++) {
2022-01-19 11:08:55 +08:00
if (map.containsKey(nums[i]) && i - map.get(nums[i]) <= k) {
return true;
2021-09-01 12:42:39 +08:00
}
2022-01-19 11:08:55 +08:00
map.put(nums[i], i);
2021-09-01 12:42:39 +08:00
}
return false;
}
}
//leetcode submit region end(Prohibit modification and deletion)
}