LeetCode 面试经典150题 [45/150 存在重复元素II]


avatar
GuoYulong 2024-06-26 160

题目描述

给你一个整数数组 nums 和一个整数 k ,判断数组中是否存在两个 不同的索引 i 和 j ,满足 nums[i] == nums[j] 且 abs(i - j) <= k 。如果存在,返回 true ;否则,返回 false 示例 1:

复制代码
  1. 输入:nums = [1,2,3,1], k = 3
  2. 输出:true

示例 2:

复制代码
  1. 输入:nums = [1,0,1,1], k = 1
  2. 输出:true

个人C++解答


刚一看到这道题就应该想到是滑动窗口,且是固定窗口大小的滑动窗口,由于找重复值,可以考虑用哈希表,将窗口模拟为哈希表,当窗口大小小于K时,窗口增加,当窗口到达大小时,通过减小首个进入窗口的值去缩小窗口,可以通过在nums数组中该值的下标来找到这个值,代码中以right表示窗口右侧。

GYL
复制代码
  1. class Solution {
  2. public:
  3. bool containsNearbyDuplicate(vector<int>& nums, int k) {
  4. unordered_map<int, int> HashMap;
  5. int right = 0;
  6. for (; right < nums.size(); ++right) {
  7. if (HashMap.count(nums[right])) {
  8. return true;
  9. }
  10. HashMap[nums[right]]++;
  11. if (HashMap.size() > k) {
  12. HashMap.erase(nums[right - k]);
  13. }
  14. }
  15. return false;
  16. }
  17. };

相关阅读

注意!!!

站点域名更新!!!部分文章图片等由于域名问题无法显示!!!

通知!!!

站点域名更新!!!部分文章图片等由于域名问题无法显示!!!