如何解决leetcode中存在重复元素的问题
发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,这篇文章主要介绍如何解决leetcode中存在重复元素的问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!题目链接https://leetcode-cn.com/problem
千家信息网最后更新 2025年12月03日如何解决leetcode中存在重复元素的问题
这篇文章主要介绍如何解决leetcode中存在重复元素的问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
题目链接
https://leetcode-cn.com/problems/contains-duplicate-ii/
题目描述
给定一个整数数组和一个整数 k,判断数组中是否存在两个不同的索引 i 和 j,使得 nums [i] = nums [j],并且 i 和 j 的差的绝对值最大为 k。
示例 1:
输入: nums = [1,2,3,1], k = 3
输出: true
示例 2:
输入: nums = [1,0,1,1], k = 1
输出: true
示例 3:
输入: nums = [1,2,3,1,2,3], k = 2
输出: false
解题方案
思路
标签:哈希
维护一个哈希表,里面始终最多包含k个元素,当出现重复值时则说明在k距离内存在重复元素
每次遍历一个元素则将其加入哈希表中,如果哈希表的大小大于k,则移除最前面的数字
时间复杂度:O(n),n为数组长度
代码
Java版本
class Solution {
public boolean containsNearbyDuplicate(int[] nums, int k) {
HashSet set = new HashSet<>();
for(int i = 0; i < nums.length; i++) {
if(set.contains(nums[i])) {
return true;
}
set.add(nums[i]);
if(set.size() > k) {
set.remove(nums[i - k]);
}
}
return false;
}
}
JavaScript版本
/**
* @param {number[]} nums
* @param {number} k
* @return {boolean}
*/
var containsNearbyDuplicate = function(nums, k) {
const set = new Set();
for(let i = 0; i < nums.length; i++) {
if(set.has(nums[i])) {
return true;
}
set.add(nums[i]);
if(set.size > k) {
set.delete(nums[i - k]);
}
}
return false;
};
画解

以上是"如何解决leetcode中存在重复元素的问题"这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!
元素
哈希
数组
示例
输入
输出
问题
内容
整数
版本
篇文章
题目
不同
复杂
最大
两个
代码
价值
兴趣
内存
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全最好的上市公司
打印机服务器怎么下载驱动
目前比较流行的服务器操作系统有
计算机网络技术和铁路有关吗
淮安创新软件开发业务流程
台州百泰网络技术公司
网络安全就业的最低工资标准
广东省数字政府网络安全指数解读
大数据是软件开发
软件开发需要做什么工作
软件开发需要哪些设计基础
机核数据库
软件开发几年学会
wind数据库 教学视频
db2 数据库 导出
僵尸部队4联机服务器
金融信用数据库会恢复吗
阿克苏联想服务器维保公司
崇明区软件开发怎么样
求生之路2服务器srv转接
阿里腾讯的网络安全
软件开发的绩效考核表
网络安全年度考核教育
oracle12c数据库设置
通信网络安全与对抗
百度服务器为什么在美国
服务器的告警温度范围
碧蓝航线 各服务器兑换
肇庆数据库营销公司排名
企业选择服务器