如何解决leetcode中存在重复元素的问题
发表于:2025-02-05 作者:千家信息网编辑
千家信息网最后更新 2025年02月05日,这篇文章主要介绍如何解决leetcode中存在重复元素的问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!题目链接https://leetcode-cn.com/problem
千家信息网最后更新 2025年02月05日如何解决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安全错误
数据库的锁怎样保障安全
数据库系统三级模式由什么组成
特色数据库是指
plc怎么存储几个数据库
厦门励航软件开发
刑法修正网络安全规定
靠谱的仓库管理软件开发
做缓存服务器赚钱
游戏网络技术公司招聘
服务器无法访问
企业的网络安全管理员承认吗
网络技术入门视频教程
软件开发与运维流程
上海优目网络技术
网络安全和发展
网络安全宣传教育节目
剑网3 服务器
深圳人脉通网络技术有限公司
如果提软件开发需求
东莞海鲜冷库软件开发
移动基站数据库
聊城诚信积分管理软件开发软件
率土之滨今日服务器维护
web服务器配置中默认端口号是
网络安全法五类义务
网络安全毕业薪水在多少
泰坦之旅服务器怎么搭建
数据库查看表字节大小
湘潭县计算机网络技术
数据库应用技术网课
校园网络安全维护记录表