当前位置: 首页 > news >正文

力扣:219. 存在重复元素 II

力扣:219. 存在重复元素 II

给你一个整数数组 nums 和一个整数 k ,判断数组中是否存在两个 不同的索引 i 和 j ,满足 nums[i] == nums[j] 且 abs(i - j) <= k 。如果存在,返回 true ;否则,返回 false 。
在这里插入图片描述

方法一:哈希表

#include<iostream>
#include<unordered_map>using namespace std;class Solution {
public:bool containsNearbyDuplicate(vector<int>& nums, int k) {unordered_map<int, int> m;for (int i = 0; i < nums.size(); i++) {if (m.count(nums[i]) > 0 && abs(m[nums[i]] - i) <= k) {return true;}m[nums[i]] = i;}return false;}
};int main()
{ Solution solution;vector<int> duplicate{ 1,2,3,1 };int result = solution.containsNearbyDuplicate(duplicate,3);cout << result << endl;return 0;
}

在这里插入图片描述

方法二:滑动窗口

制造一个i-k-1的窗口,加入当前窗口位置的数组成员,超过窗口范围的删除,在此窗口中查找有无重复的数字,有则为真,无则为假

#include<iostream>
#include<unordered_set>using namespace std;class Solution {
public:bool containsNearbyDuplicate(vector<int>& nums,int k) {unordered_set<int> s;int length = nums.size();for (int i = 0; i < length; ++i) {if (i > k) {s.erase(nums[i - k - 1]);}if (s.count(nums[i])) {return true;}s.emplace(nums[i]);}return false;}
};int main()
{Solution solution;vector<int> duplicate{ 1,2,3,1 };int result = solution.containsNearbyDuplicate(duplicate, 3);cout << result << endl;return 0;
}

在这里插入图片描述

http://www.lryc.cn/news/341154.html

相关文章:

  • 程序安装 - 笔记
  • 文心一言 vs. GPT-4: 全面比较
  • 图书管理系统概述
  • 中国老铁路增开对国际旅客列车开行
  • 搭建个人智能家居 4 -WS2812B-RGB灯
  • C++类与对象(中)②
  • Qt——xml文件生成DBus接口
  • 初识SpringMVC(SpringMVC学习笔记一)
  • FreeRTOS任务管理
  • Qwen1.5大语言模型微调实践
  • 购物车实现
  • HTML5漫画风格个人介绍源码
  • 工业数学模型——高炉煤气发生量预测(三)
  • pnpm - Failed to resolve loader: cache-loader. You may need to install it.
  • CSS transition和animation的用法和区别
  • 书籍推荐(附上每本书的看点)
  • LLM理解v1
  • ubuntu 22.04 -- cmake安装
  • 字符串算法题(第二十四天)
  • 【Linux】应用层协议序列化和反序列化
  • 使用Canal同步MySQL 8到ES中小白配置教程
  • 关于部署ELK和EFLK的相关知识
  • 实验室信息系统源码 saas模式java+.Net Core版开发的云LIS系统全套源码可二次开发有演示
  • PCB---Design Entry cis 绘图 导出
  • vue 一键更换主题颜色
  • WebKit内核游览器
  • Qt 拖放功能详解:理论与实践并举的深度指南
  • Springboot+Vue项目-基于Java+MySQL的企业客户管理系统(附源码+演示视频+LW)
  • 【Linux学习】Linux指令(四)
  • 阿里云服务器 使用Certbot申请免费 HTTPS 证书及自动续期