220. Contains Duplicate III
# Medium
class Solution {
public:
bool containsNearbyAlmostDuplicate(vector<int>& nums, int k, int t) {
map<long long, int> m;
int base = 0;
for(int i = 0; i < nums.size(); i ++) {
if(i - base > k) m.erase(nums[base++]);
auto a = m.lower_bound((long long)nums[i]-t);
if(a != m.end() && abs(a->first - nums[i]) <= t)
return true;
m[nums[i]] = i;
}
return false;
}
};
Last updated
Was this helpful?