题目描述
在整数数组 nums
中,是否存在两个下标 i 和 j,使得 nums [i]
和 nums [j]
的差的绝对值小于等于 t ,且满足 i 和 j 的差的绝对值也小于等于 ķ 。
如果存在则返回 true,不存在返回 false。
示例:
输入: nums = [1,2,3,1], k = 3, t = 0
输出: true
示例2:
输入: nums = [1,0,1,1], k = 1, t = 2
输出: true
题目思路
暴力法
直接查找元素
class Solution {
public boolean containsNearbyAlmostDuplicate(int[] nums, int k, int t) {
/**
* 遍历一遍,存在则返回,时间复杂度为O(n*k),空间复杂度为O(1)
*/
for (int i = 0; i < nums.length; i++) {
for (int j = i + 1; j <= i + k; j++) {
if (j < nums.length) {
if (Math.abs((long)nums[j] - (long)nums[i]) <= t) return true;
}
}
}
return false;
}
}
集合法
class Solution {
public boolean containsNearbyAlmostDuplicate(int[] nums, int k, int t) {
if (nums.length == 0 || k == 0){
return false;
}
Set<Integer> set = new HashSet<>();
for(int i = 0; i < nums.length; i++){
if (t == 0){
if (set.contains(nums[i])){
return true;
}
}
else{
for(int num : set){
if (Math.abs((long)nums[i] - (long)num) <= t){
return true;
}
}
}
set.add(nums[i]);
if (set.size() > k){
set.remove(nums[i - k]);
}
}
return false;
}
}