leetcode怎么查看数组中重复的数字
发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,这篇文章主要介绍了leetcode怎么查看数组中重复的数字,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。题目链接https://lee
千家信息网最后更新 2025年01月23日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安全错误
数据库的锁怎样保障安全
燃烧的意志服务器哪种好
微信登录未安装到服务器
数据库快照的用途
开发票软件开发服务属于什么类目
为什么有些软件开发员要手机
广东专业软件开发源头好货
新科技互联网智能时代
16网络安全周的logo
查看数据库备份文件
推广网络技术咨询一体化
服务器开不开机
菜鸟数据库
公司网络安全实施统一管理
访问控制在网络安全的原理
戴尔服务器t420多少钱
互联网之光博览会有哪些黑科技
数据库大数据量topn优化
软件开发培养要求
华为服务器不兼容说明书
信息安全中数据库安全
宁夏兴庆区软件开发找哪家
杭州玖旺网络技术有限公司
提示网络安全博览会
高颜值数据库技术
关系数据库pk和fk
广东dns服务器地址云空间
贵州网络时间同步服务器云空间
hp官网服务器页面
计算机网络技术以后能干啥
陕西超频服务器哪里好