题目描述
给你一个整数数组 nums 和一个整数 k ,判断数组中是否存在两个 不同的索引 i 和 j ,满足 nums[i] == nums[j] 且 abs(i - j) <= k 。如果存在,返回 true ;否则,返回 false 示例 1:
输入:nums = [1,2,3,1], k = 3 输出:true
示例 2:
输入:nums = [1,0,1,1], k = 1 输出:true
个人C++解答
GYL
刚一看到这道题就应该想到是滑动窗口,且是固定窗口大小的滑动窗口,由于找重复值,可以考虑用哈希表,将窗口模拟为哈希表,当窗口大小小于K时,窗口增加,当窗口到达大小时,通过减小首个进入窗口的值去缩小窗口,可以通过在nums数组中该值的下标来找到这个值,代码中以right表示窗口右侧。
class Solution { public: bool containsNearbyDuplicate(vector<int>& nums, int k) { unordered_map<int, int> HashMap; int right = 0; for (; right < nums.size(); ++right) { if (HashMap.count(nums[right])) { return true; } HashMap[nums[right]]++; if (HashMap.size() > k) { HashMap.erase(nums[right - k]); } } return false; } };