前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >数组中的重复数字

数组中的重复数字

原创
作者头像
用户9955628
发布于 2022-08-22 07:22:14
发布于 2022-08-22 07:22:14
1.6K00
代码可运行
举报
文章被收录于专栏:python3基础算法python3基础算法
运行总次数:0
代码可运行
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
"""
描述
在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组[2,3,1,0,2,5,3],那么对应的输出是2或者3。存在不合法的输入的话输出-1

数据范围:0\le n \le 10000 \0≤n≤10000
进阶:时间复杂度O(n)\O(n) ,空间复杂度O(n)\O(n)
示例1
输入:
[2,3,1,0,2,5,3]
复制
返回值:
2
复制
说明:
23都是对的
数据范围:0\le n \le 10000 \0≤n≤10000
进阶:时间复杂度O(n)\O(n) ,空间复杂度O(n)\O(n)
"""

# @param numbers int整型一维数组
# @return int整型
#
from typing import List

class Solution:
    def duplicate(self , numbers: List[int]) -> int:
        # write code here
        for i, num in enumerate(numbers):
            while num[i] != i:
                m = numbers[i]
                if numbers[m] == m:
                    return m
            else:
                numbers[i] = numbers[m]
                numbers[m] = m
        return -1

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
剑指Offer(五十)-- 数组中重复的数字
在一个长度为n的数组里的所有数字都在0到n-1的范围内。数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中第一个重复的数字。例如,如果输入长度为7的数组[2,3,1,0,2,5,3],那么对应的输出是第一个重复的数字2。没有重复的数字返回-1。
秦怀杂货店
2022/02/15
3130
剑指Offer(五十)-- 数组中重复的数字
【剑指Offer】3. 数组中重复的数字
在一个长度为 n 的数组里的所有数字都在 0 到 n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字是重复的,也不知道每个数字重复几次。请找出数组中任意一个重复的数字。
瑞新
2020/12/07
2260
剑指Offer-数组中重复的数字
package Array; /** * 数组中重复的数字 *在一个长度为n的数组里的所有数字都在0到n-1的范围内。 * 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 * 例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。 * 思路: * 数组中的数字都在0到n-1的数字范围内。如果数组中没有重复出现的数字,那么当数组排序后数字i就出现在数组中下标为i的元素处。那么数组中如果存在重
武培轩
2018/04/18
9120
【剑指offer】数组中重复的数字
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
喜欢ctrl的cxk
2019/11/08
7190
剑指50-数组中重复的数字
在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。
opencode
2022/12/26
2250
剑指offer(二):不修改数组找出重复的数字
在一个长度为 n+1 的数组里的所有数字都在 1 到 n 的范围内,所以数组中至少有一个数字是重复的。请找出数组中任意一个重复的数字,但不能修改输入的数组。例如,如果输入长度为 8 的数组 {2, 3, 5, 4, 3, 2, 6, 7},那么对应的输出是重复的数字 2 或者 3。
程序员小浩
2020/08/04
8140
剑指offer(二):不修改数组找出重复的数字
面试题03. 数组中重复的数字
找出数组中重复的数字 在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。
lexingsen
2022/02/24
1530
剑指 offer 面试题精讲图解 | 03 . 数组中重复的数字
今天分享的题目来源于 LeetCode 上的剑指 Offer 系列 面试题03. 数组中重复的数字。
五分钟学算法
2020/05/29
5100
剑指 offer 面试题精讲图解 | 03 . 数组中重复的数字
每日一题《剑指offer》数组篇之数组中重复的数字
在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组[2,3,1,0,2,5,3],那么对应的输出是2或者3。存在不合法的输入的话输出-1
终有救赎
2023/11/08
2220
每日一题《剑指offer》数组篇之数组中重复的数字
剑指offer(一):找出数组中重复的数字
在一个长度为 n 的数组里的所有数字都在 0 到 n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。例如,如果输入长度为 7 的数组 {2, 3, 1, 0, 2, 5, 3},那么对应的输出是重复的数字 2 或者 3。
程序员小浩
2020/08/04
6720
画解算法:面试题3. 数组中重复的数字
https://leetcode-cn.com/problems/shu-zu-zhong-zhong-fu-de-shu-zi-lcof/
FunTester
2020/04/03
5030
画解算法:面试题3. 数组中重复的数字
剑指offer——数组中重复的数字
题目描述 在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。 示例1 输入 复制 输出 复制
AI那点小事
2020/04/18
5860
数组面试题-大力出奇迹?
一般做法可能是吧数组排序,然后只需从头到尾扫描排序后的数组就可以了,复杂度是 。还可以借助哈表,判断是否存在重复数字,时间复杂度是 但是也需要 大小的空间。我们来看一种时间复杂度是 且空间复杂度是 的做法。因为数字范围是0~n-1,当没有重复数字时,数字i将出现在下标为i的位置,当有重复数字时有些位置就可能存在多个数字。从头到尾扫描这个数字中的每个数字,当扫描到下标为i的数字是,比较这个数字(设为m)是否和i相同,若相同则继续扫描下一个数字;否则拿它和下标为m的数字比较,如果相同就找到了一个重复的数字,否则交换这两个数字。
唔仄lo咚锵
2022/05/09
6110
数组面试题-大力出奇迹?
Sword To Offer 050 - 数组中重复的数字
在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。
Reck Zhang
2021/08/11
4250
《剑指 offer》刷题记录之:数组
题目中的限制可以让我们不用去判断数组是否为空。一种比较简单的方法是先把输入的数组「排序」,再从排序的数组中找出重复的数字。但是排序一个长度为 n 的数组一般需要较大的时间与空间复杂度,以归并排序为例,其时间复杂度为
口仆
2020/08/14
8870
[PHP] 算法-数组重复数字统计的PHP实现
在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。 1.哈希法 2.定义备用数组,作为哈希使用,key是原数组每个元素 value是出现的次数 3.遍历哈希数组 hash for i=0i;<arr.length;i++ hash[arr[i]]++; foreach hash as
唯一Chat
2019/09/10
1.2K0
每日一题《剑指offer》数组篇之调整数组顺序使奇数位于偶数前面
输入一个长度为 n 整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前面部分,所有的偶数位于数组的后面部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。
终有救赎
2023/10/16
1980
每日一题《剑指offer》数组篇之调整数组顺序使奇数位于偶数前面
数组中重复的数字---java版做的么啥意思
在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。
名字是乱打的
2022/05/13
3200
LeetCode题解—重复数字
本来今天应该继续说Android系统方面的知识,但是我发现内容有点多,写不完了?。 那,为了保证文章的质量,所以今天就发一篇算法题顶上了~❤️ 算法题也是面试常考的项,之前也说过,虽然用到的比较少,但
码上积木
2021/01/25
4790
剑指 03— 数组中重复的数字
在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。
Java架构师必看
2021/05/14
6580
推荐阅读
相关推荐
剑指Offer(五十)-- 数组中重复的数字
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验