Given an integer array nums and two integers k and t, return true if there are two distinct indicesi and j in the array such that abs(nums[i] - nums[j]) <= t and abs(i - j) <= k.
Example 1:
**Input:** nums = [1,2,3,1], k = 3, t = 0
**Output:** true
Example 2:
**Input:** nums = [1,0,1,1], k = 1, t = 2
**Output:** true
Example 3:
**Input:** nums = [1,5,9,1,5,9], k = 2, t = 3
**Output:** false
Constraints:
0 <= nums.length <= 2 * 104
-231 <= nums[i] <= 231 - 1
0 <= k <= 104
0 <= t <= 231 - 1
ac1: TreeSet
TreeSet is Black-Red Tree, self balance tree, sorted.
classSolution {publicbooleancontainsNearbyAlmostDuplicate(int[] nums,int k,int t) {if (t <0) returnfalse;Map<Long,Long> buckets =newHashMap<Long,Long>();long size = (long)t +1;for (int i =0; i <nums.length; i++) {long ival = (long) nums[i];long label =getId(ival, size);if (buckets.containsKey(label)) returntrue;if (buckets.containsKey(label -1) &&Math.abs(buckets.get(label-1) - ival) <= t) returntrue;if (buckets.containsKey(label +1) &&Math.abs(buckets.get(label+1) - ival) <= t) returntrue;buckets.put(label, ival);if (i >= k) {buckets.remove(getId((long)nums[i-k], size)); } }returnfalse; }privateLonggetId(long num,long size) {return num <0? num / size -1: num / size;// in Java, -3 / 5 == 0, but we need -3 / 5 == -1, so we minus 1. }}// O(n)// Why "Math.abs(buckets.get(label-1) - ival) <= t)"? Because 1 bucket can only has one element, if it has more than 1, "buckets.containsKey(label)" will return true earlier.