leetcode怎么查看数组中重复的数字
发表于:2025-12-01 作者:千家信息网编辑
千家信息网最后更新 2025年12月01日,这篇文章主要介绍了leetcode怎么查看数组中重复的数字,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。题目链接https://lee
千家信息网最后更新 2025年12月01日leetcode怎么查看数组中重复的数字
这篇文章主要介绍了leetcode怎么查看数组中重复的数字,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
题目链接
https://leetcode-cn.com/problems/shu-zu-zhong-zhong-fu-de-shu-zi-lcof/
题目描述
找出数组中重复的数字。
在一个长度为 n 的数组 nums 里的所有数字都在 0 ~ n-1 的范围内。数组中某些数字是重复的,
但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个
重复的数字。
示例 1:
输入:
[2, 3, 1, 0, 2, 5, 3]
输出:2 或 3
限制:
2 <= n <= 100000
解题方案
思路 1
标签:哈希 使用 HashSet 来进行处理,因为 HashSet 本身不允许出现重复元素,所以 当添加元素失败或已经包含该数字时,则表示出现了重复元素,将其返回即可。思路较为简单,就不给图了 时间复杂度:O(n),空间复杂度:O(n)
代码 1
Java 版本
class Solution {
public int findRepeatNumber(int[] nums) {
Set numsSet = new HashSet<>();
for(int num: nums) {
if(!numsSet.add(num)) {
return num;
}
}
return -1;
}
}
JavaScript 版本
/**
* @param {number[]} nums
* @return {number}
*/
var findRepeatNumber = function(nums) {
const numsSet = new Set();
for(const num of nums) {
if(numsSet.has(num)) {
return num;
} else {
numsSet.add(num);
}
}
return -1;
};
思路 2
标签:哈希 从题目描述中我们可以看出,因为所有数字都在 0 ~ n-1 的范围内,其实完全可以省掉额外的空间开辟,将每个位置的数交换映射到其对应的数组下标下面,当出现新的元素与其对应的下标中的数字相等时,即为重复数字 这本质还是哈希的思想,思路 1 是使用库函数申请额外空间,思路 2 则是数组本身做哈希表,达到了节省空间的目的 此处会用到 while 循环,原因是保证交换过来的新元素位置也要正确 时间复杂度:O(n),空间复杂度:O(1)
代码 2
Java 版本
class Solution {
public int findRepeatNumber(int[] nums) {
int len = nums.length;
for (int i = 0; i < len; i++) {
while (nums[i] != i) {
if (nums[i] == nums[nums[i]]) {
return nums[i];
}
int temp = nums[i];
nums[i] = nums[temp];
nums[temp] = temp;
}
}
return -1;
}
}
JavaScript 版本
/**
* @param {number[]} nums
* @return {number}
*/
var findRepeatNumber = function(nums) {
const len = nums.length;
for (let i = 0; i < len; i++) {
while (nums[i] != i) {
if (nums[i] == nums[nums[i]]) {
return nums[i];
}
const temp = nums[i];
nums[i] = nums[temp];
nums[temp] = temp;
}
}
return -1;
};
画解 2
横滑见完整画解

感谢你能够认真阅读完这篇文章,希望小编分享的"leetcode怎么查看数组中重复的数字"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!
数字
数组
元素
思路
空间
复杂
复杂度
版本
篇文章
哈希
题目
下标
代码
位置
时间
标签
范围
价值
兴趣
函数
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
最残酷的网络技术
app软件开发使用条件
电脑服务器号和密码都在哪里
陕西电商软件开发公司
互联网科技转正汇报ppt
国网公司网络安全建议
QT软件开发工程师招聘
安徽网络安全工程专业排名
管理ip登录服务器
汕头网络安全执法
各种威胁网络安全的技术
企业组网需要服务器吗
博学易知数据库评价
戴尔服务器质保
企业信息和网络安全报道
网络安全法国家安全
游戏软件开发怎么
关系型数据库的基本结构
华为服务器安装欧拉系统教程
黄埔区机电软件开发项目信息
互联网科技社
网络安全大赛歌曲得奖
淘宝是什么软件开发出来的
有内鬼无法连接服务器
如何配置和管理web服务器
乌班图常用数据库
学数据库还是软件开发
数据库怎么显示出来的
山西运城dns服务器地址
手机网络安全为主题黑板报