存在重复元素 III

给你一个整数数组 nums 和两个整数 k 和 t 。请你判断是否存在 两个不同下标 i 和 j,使得 abs(nums[i] - nums[j]) <= t ,同时又满足 abs(i - j) <= k 。
如果存在则返回 true,不存在返回 false。

  • 输入:nums = [1,2,3,1], k = 3, t = 0
    输出:true

  • 输入:nums = [1,0,1,1], k = 1, t = 2
    输出:true

1
2
3
4
5
6
7
8
var containsNearbyAlmostDuplicate = function(nums, k, t) {
for (let i = 0; i < nums.length; i++) {
for (let j = i + 1; j <= i + k && j < nums.length; j++) {
if (Math.abs(nums[j] - nums[i]) <= t) return true;
}
}
return false;
};