首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

数组中重复数字

题目描述 在一个长度为n数组里所有数字都在0到n-1范围内。 数组中某些数字重复,但不知道有几个数字重复。也不知道每个数字重复几次。请找出数组中任意一个重复数字。...例如,如果输入长度为7数组{2,3,1,0,2,5,3},那么对应输出是第一个重复数字2。 解题思路 最简单就是用一个数组或者哈希表来存储已经遍历过数字,但是这样需要开辟额外空间。...如果题目要求不能开辟额外空间,那我们可以用如下方法: 因为数组中数字都在0~n-1范围内,所以,如果数组中没有重复数,那当数组排序后,数字i将出现在下标为i位置。...如果是,则接着扫描下一个数字;如果不是,则再拿它和m 位置上数字进行比较,如果它们相等,就找到了一个重复数字(该数字在下标为i和m位置都出现了),返回true;如果它和m位置上数字不相等,就把第...i个数字和第m个数字交换,把m放到属于它位置。

2K30

查找数组中重复数字

题目来源于《剑指Offer》中面试题3:找出数组中重复数字。   // 题目:在一个长度为n数组里所有数字都在0到n-1范围内。...数组中某些数字重复,但不知道有几个数字重复了,   // 也不知道每个数字重复了几次。请找出数组中任意一个重复数字。...例如,如果输入长度为7数组{2, 3, 1, 0, 2, 5, 3},   // 那么对应输出是重复数字2或者3。        ...: (输出) 数组中一个重复数字 // 返回值: // true - 输入有效,并且数组中存在重复数字 // false - 输入无效,或者数组中没有重复数字...\n"); } // 重复数字是数组中最小数字 void test1() { int numbers[] = { 2, 1, 3, 1, 4 }; int duplications

3.9K60

寻找数组中重复数字

规则如下: 给定一个长度为n数组,数组中每个元素取值范围为:0~n-1 数组中某些数字重复,但是不知道哪些数字重复了,也不知道重复了几次 求数组中任意一个重复数字 实现思路 这个问题实现思路有三种...排序方法实现 用排序方法实现分为两步: 先用快速排序对数组进行排序 遍历排序好数组,如果其相邻两个元素相等就代表数组中有重复数字,将其返回即可。 接下来,我们通过一个例子来验证下上述思路。...== 3,继续下一轮遍历 i = 2时,i号位置元素为3,i+1位置元素是3,3 === 3,数组中有重复数字,存储i号位置元素,退出循环。...动态排序法实现 根据题意可知,数组中元素取值范围在0~n-1,那么就可以得到如下结论: 如果数组中没有重复元素,那么第i号元素值一定是当前下标(i) 如果数组中有重复元素,那么有些位置可能存在多个数字...=0,数组3号位置元素为3,3 === 3,元素重复,返回m。 问题解决,重复数字为3。

1.3K10

高效寻找缺失和重复数字

但是现在出现了一些错误,nums中一个元素出现了重复,也就同时导致了另一个元素缺失。请你写一个算法,找到nums中重复元素和缺失元素值。...其实很容易解决这个问题,先遍历一次数组,用一个哈希表记录每个数字出现次数,然后遍历一次[1..N],看看那个元素重复出现,那个元素没有出现,就 OK 了。...但问题是,这个常规解法需要一个哈希表,也就是 O(N) 空间复杂度。你看题目给条件那么巧,在[1..N]几个数字中恰好有一个重复,一个缺失,事出反常必有妖,对吧。...那么,如果我能够通过某些方法,找到这个重复对应索引,不就是找到了那个重复元素么?找到那个没有元素对应索引,不就是找到了那个缺失元素了么? 那么,如何不使用额外空间判断某个索引有多少个元素对应呢?...因为如果元素从 0 开始,那么 0 相反数还是自己,所以如果数字 0 出现了重复或者缺失,算法就无法判断 0 是否被访问过。我们之前假设只是为了简化题目,更通俗易懂。

58130

LeetCode题解—重复数字

今天和大家看看剑指 Offer上一题:数组中重复数字。 题目:数组中重复数字 在一个长度为 n 数组 nums 里所有数字都在0~n-1范围内。...数组中某些数字重复,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复数字。...所以我们可以利用那些没有重复、成员唯一集合,比如HashSet。 HashSet特点就是唯一和无序,所以只要我们把数组中数字加到HashSet中,如果出现重复数字,就会加入失败。...当发现一个坑有两个萝卜时候,就是有重复数字发生了。...=0,while条件true,但是此时位置为2坑位已经被同样数字占据了,所以这个2就是重复数字,return。

43930

LeetCode108|数组中重复数字

0x01,问题简述 找出数组中重复数字。 在一个长度为 n 数组 nums 里所有数字都在 0~n-1 范围内。数组中某些数字重复,但不知道有几个数字重复了,也不知道每个数字重复了几次。...请找出数组中任意一个重复数字。...1, 0, 2, 5, 3] 输出:2 或 3 限制: 2 <= n <= 100000 0x03,题解思路 这里给出两种解决方式,一个是使用键值对集合HashMap进行解决,一个使用数组方式进行解决...} return -1; } } 0x05,题解程序图片版 0x06,总结一下 其实,每次题解做完之后,总结性的话就变得很少了,我倒是觉得程序完全就体现了整个内容,过多注释性说明真的那么重要吗...,对于输出者而言就是一种简单描述而已,或许对于读者而言就是很好内容说明吧

47820

剑指 03— 数组中重复数字

数组中重复数字 难度简单372 找出数组中重复数字。 在一个长度为 n 数组 nums 里所有数字都在 0~n-1 范围内。...数组中某些数字重复,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复数字。...使用哈希集合(HashSet),添加元素时间复杂度为 O(1),故总时间复杂度是 O(n) 空间复杂度:O(n)。 不重复每个元素都可能存入集合,因此占用 O(n)额外空间。...key == val 如果当前数字 nums[i] 和索引 i 不相等,那么应该把 nums[i] 放在索引也为 nums[i] 位置去,就把索引为 nums[i] 和 i 数字对换 如果数组在索引为...nums[i] 位置数在交换前就已经是 nums[i],说明nums[i]是重复数字,返回nums[i] 如果交换后在 nums[i] 仍然不等于 i,要继续交换,这是使用while循环原因

57320
领券