【C++刷题】力扣-#219-存在重复元素II

题目描述

给定一个整数数组 nums 和一个整数 k,判断数组中是否存在两个不同的索引 i 和 j 使得 nums[i] = nums[j] 且 i!= j。也就是说,不能有重复的元素。

示例

示例 1:

输入: nums = [1,2,3,1], k = 3
输出: true

示例 2:

输入: nums = [1,2,3,1,2,4], k = 3
输出: false

示例 3:

输入: nums = [1,2,3,1,2,4], k = 2
输出: true

题解

这个问题可以通过使用哈希表来解决。

  1. 初始化:创建一个空的哈希表 hashMap 来存储数组元素及其索引。
  2. 遍历数组:遍历整数数组 nums。
    ○ 对于每个元素,检查它是否已经在哈希表中:
    ■ 如果在,并且索引差小于 k,则返回 true。
    ■ 如果在,并且索引差大于等于 k,则从哈希表中移除旧的索引。
    ■ 如果不在,将其添加到哈希表中,并记录当前索引。
  3. 返回结果:如果遍历结束后没有找到重复元素,则返回 false。

代码实现

bool containsNearbyDuplicate(vector<int>& nums, int k) {unordered_map<int, int> hashMap;for (int i = 0; i < nums.size(); ++i) {if (hashMap.find(nums[i]) != hashMap.end() && i - hashMap[nums[i]] <= k) {return true;}hashMap[nums[i]] = i;}return false;
}

复杂度分析

● 时间复杂度:O(n),其中 n 是数组 nums 的长度。我们需要遍历一次数组,并且对于每个元素,我们进行常数时间的哈希表操作。
● 空间复杂度:O(n),因为在最坏的情况下,我们可能需要将所有元素存储在哈希表中。
这个算法的优势在于它的时间效率较高,只需要一次遍历即可判断是否存在重复元素,且直接利用了哈希表的快速查找特性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/882126.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringColoud GateWay 核心组件

优质博文&#xff1a;IT-BLOG-CN 【1】Route路由&#xff1a; Gateway的基本构建模块&#xff0c;它由ID、目标URL、断言集合和过滤器集合组成。如果聚合断言结果为真&#xff0c;则匹配到该路由。 Route路由-动态路由实现原理&#xff1a; 配置变化Apollo 服务地址实例变化…

H3C设备连接方式

Console线本地连接 协议Serial&#xff0c;接口com口&#xff0c;波特率9600&#xff08;设备管理器中查看com口&#xff09; 适用于设备初次调试 使用Telnet远程访问 适用于设备上架配置好后的维护管理 使用SSH远程访问 数据传输过程加密&#xff0c;安全的远程访问

洞察数字化营销的本质

数字化营销&#xff0c;即借助互联网、移动互联网、社交媒体等数字技术与渠道实现营销目标。涵盖市场调研、品牌推广、产品销售到客户服务全过程。 其特点显著。精准定位是一大优势&#xff0c;利用大数据分析和人工智能&#xff0c;深入了解客户需求、兴趣和行为&#xff0c;精…

AdmX_new

0x00前言 因为环境问题&#xff0c;此次靶场都放在vm上。都为NAT模式。 靶机地址: https://download.vulnhub.com/admx/AdmX_new.7z 需要找到两个flag文件。 0x01信息搜集 搜集IP 确认目标IP为172.16.8.131&#xff0c;进一步信息搜集 获取端口开放情况&#xff0c;版本信…

多模态大语言模型(MLLM)-Blip3/xGen-MM

论文链接&#xff1a;https://www.arxiv.org/abs/2408.08872 代码链接&#xff1a;https://github.com/salesforce/LAVIS/tree/xgen-mm 本次解读xGen-MM (BLIP-3): A Family of Open Large Multimodal Models 可以看作是 [1] Blip: Bootstrapping language-image pre-training…

TCP/IP 寻址

TCP/IP 寻址 概述 TCP/IP(传输控制协议/互联网协议)是一组用于数据网络的通信协议。它们定义了数据如何在网络上从一个设备传输到另一个设备。在TCP/IP网络中,每个设备都有一个唯一的地址,称为IP地址,用于标识网络上的设备。本文将深入探讨TCP/IP寻址的概念、类型、分配…

Lua脚本的原子性

Lua脚本之所以被认为是原子性的,主要源于Redis的内部实现机制和Lua脚本的执行方式。以下是对Lua脚本原子性的详细解释: 一、Redis的单线程模型 Redis是一个基于内存、可基于Key-Value等多种数据结构的存储系统,它使用单线程模型来处理客户端的请求。这意味着在任何给定的时…

Vue3中防止按钮重复点击的方式

本文列两种方式&#xff0c;推荐第一种&#xff0c;经过长时间测试第二种防止的还是会漏&#xff0c;这里也列一下 ①使用定时器&#xff08;推荐&#xff09; 判断3秒钟之内方法只能执行一次 <el-button click"handleClick" type"primary" :loading…

二叉树算法之二叉树遍历(前序、中序、后序、层次遍历)

二叉树遍历是指按照某种顺序访问二叉树的所有节点。常见的二叉树遍历方式包括前序遍历&#xff08;Preorder Traversal&#xff09;、中序遍历&#xff08;Inorder Traversal&#xff09;、后序遍历&#xff08;Postorder Traversal&#xff09;和层次遍历&#xff08;Level-or…

stm32 bootloader写法

bootloader写法&#xff1a; 假设app的起始地址&#xff1a;0x08020000&#xff0c;则bootloader的范围是0x0800,0000~0x0801,FFFF。 #define APP_ADDR 0x08020000 // 应用程序首地址定义 typedef void (*APP_FUNC)(void); // 函数指针类型定义 /*main函数中调用rum_app&#x…

Luogu P1528 切蛋糕 || SCOI2005 栅栏

假设最多能满足 x x x个人&#xff0c;那么这 x x x个人一定可以是按照每个人吃蛋糕的需求将他们从小到大排序后的前 x x x个人。&#xff08;有两个人他们吃蛋糕的需求分别为 x 1 x_1 x1​和 x 2 x_2 x2​&#xff0c;且 x 1 < x 2 x_1<x_2 x1​<x2​&#xff0c;如果…

【从零开始的LeetCode-算法】504. 七进制数

给定一个整数 num&#xff0c;将其转化为 7 进制&#xff0c;并以字符串形式输出。 示例 1: 输入: num 100 输出: "202"示例 2: 输入: num -7 输出: "-10"提示&#xff1a; -107 < num < 107 我的解答 class Solution {public String convertT…

大数据存储计算平台EasyMR:大数据集群动态扩缩容,快速提升集群服务能力

在当今的数据驱动时代&#xff0c;组织面临着数据量的爆炸性增长。为了有效管理和存储这些数据&#xff0c;许多组织依赖于 Hadoop 这样的分布式存储系统。Hadoop 集群通过在多个节点上存储数据的冗余副本&#xff0c;提供了高可靠性和可扩展性。然而&#xff0c;随着数据量的不…

【MySQL】提高篇—复杂查询:多表连接(INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL JOIN)

在关系数据库中&#xff0c;数据通常分散在多个表中。为了获取相关联的数据&#xff0c;需要使用表连接&#xff08;JOIN&#xff09;操作。 表连接允许我们在一个查询中结合多个表的数据&#xff0c;这在实际应用中非常重要。 例如&#xff0c;在一个电商系统中&#xff0c;…

如何更改MySQL的root密码

前言 在管理数据库时&#xff0c;有时可能会忘记MySQL的root用户密码或需要更改默认设置的密码。以下是在Windows环境下更改MySQL root密码的详细步骤。请注意&#xff0c;这些步骤适用于MySQL 5.7及以上版本&#xff1b;对于其他版本&#xff0c;请参考相应版本的文档。 准备…

倪师学习笔记-天纪-易经入门

1、易经-易的意思 变易、变化简易、简单 2、神、象 神&#xff1a;永恒象&#xff1a;一直变&#xff0c;不会重复&#xff0c;但对应的神一样 3、机锋 突发的、短暂的具有预兆功能的事情 4、先天八卦&#xff08;伏羲八卦&#xff09; 特点&#xff1a;为体&#xff0c…

ChatGPT国内中文版镜像网站整理合集(2024/10/06)

一、GPT中文镜像站 ① yixiaai.com 支持GPT4、4o以及o1&#xff0c;支持MJ绘画 ② chat.lify.vip 支持通用全模型&#xff0c;支持文件读取、插件、绘画、AIPPT ③ AI Chat 支持GPT3.5/4&#xff0c;4o以及MJ绘画 1. 什么是镜像站 镜像站&#xff08;Mirror Site&#xff…

Spring Boot在线考试系统:JavaWeb技术的应用案例

2相关技术 2.1 MYSQL数据库 MySQL是一个真正的多用户、多线程SQL数据库服务器。 是基于SQL的客户/服务器模式的关系数据库管理系统&#xff0c;它的有点有有功能强大、使用简单、管理方便、安全可靠性高、运行速度快、多线程、跨平台性、完全网络化、稳定性等&#xff0c;非常…

几个常值问题导致formality失败debug方法

在做fomality的时候&#xff0c;如果出现寄存器unmatch问题&#xff0c;通常是由于常值推导不一致&#xff0c;导致寄存器被优化。 几个基本定位方法如下&#xff1a; 1.verify r:wrok/top/xyz_reg[0] -constant0 此命令可查看ref中的寄存器是否是常值。 2.guide guide_re…

英飞达医学影像存档与通信系统 WebUserLogin.asmx 信息泄露漏洞复现

0x01 产品简介 英飞达医学影像存档与通信系统 Picture Archiving and Communication System,它是应用在医院影像科室的系统,主要的任务就是把日常产生的各种医学影像(包括核磁,CT,超声,各种X光机,各种红外仪、显微仪等设备产生的图像)通过各种接口(模拟,DICOM,网络…