博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
(python版) Leetcode-287. 寻找重复数
阅读量:4091 次
发布时间:2019-05-25

本文共 1196 字,大约阅读时间需要 3 分钟。

01 题目

链接 https://leetcode-cn.com/problems/find-the-duplicate-number/

给定一个包含 n + 1 个整数的数组 nums,其数字都在 1 到 n 之间(包括 1 和 n),可知至少存在一个重复的整数。假设只有一个重复的整数,找出这个重复的数。

示例 1:

输入: [1,3,4,2,2]

输出: 2

示例 2:

输入: [3,1,3,4,2]

输出: 3

说明

不能更改原数组(假设数组是只读的)。
只能使用额外的 O(1) 的空间。
时间复杂度小于 O(n2) 。
数组中只有一个重复的数字,但它可能不止重复出现一次。

02 解析

二分法

按题目表达,设数组长度为nn,则数组中元素∈[1,n−1],且只有一个重复元素。一个直观的想法,设一个数字k∈[1,n−1],统计数组中小于等于kk的数字的个数countcount:

若count<=kcount<=k,说明重复数字一定在(k,n-1](k,n−1]的范围内。若count>kcount>k,说明重复数字一定在[0,k][0,k]的范围内。

利用这个性质,我们使用二分查找逐渐缩小重复数字所在的范围。

  1. 初试化左右 数字 边界left=1,right=n-1left=1,right=n−1
  2. 循环条件left<rightleft<right:
    mid=(left+right)//2mid=(left+right)//2
    √ 按照性质,统计数组中小于等于midmid的元素个数countcount
    √ 若 count<=mid,说明重复数字一定在(mid,right](mid,right]的范围内。令left=mid+1left=mid+1
    √ 若count>mid,说明重复数字一定在[left,mid][left,mid]的范围内。令right=midright=mid。
  3. 返回leftleft

复杂度分析

时间复杂度:O\left(nlog(n)\right)O(nlog(n)),二分法执行了log(n)log(n)次遍历nn,因此复杂度为O\left(nlog(n)\right)O(nlog(n))。
空间复杂度:O(1)O(1)

链接:https://leetcode-cn.com/problems/find-the-duplicate-number/solution/er-fen-fa-kuai-man-zhi-zhen-zhu-xing-jie-shi-pytho/

03 代码

class Solution:    def findDuplicate(self, nums: List[int]) -> int:        left = 1        right = len(nums) - 1        while(left

转载地址:http://lujii.baihongyu.com/

你可能感兴趣的文章
WTF?GitHub 疑似遭受大范围中间人攻击?!
查看>>
天秀!只用 280 字,把一条推特长度的代码玩出花...
查看>>
天秀!GitHub 硬核项目:动漫生成器让照片秒变手绘日漫风!!!
查看>>
面试了 15 位来自 985/211 高校的 2020 届研究生,我熬夜赶出了这篇文章
查看>>
连苹果都在用的开源库:core-js 作者被判入狱 18 个月!
查看>>
没用过这些 IDEA 插件?怪不得你写代码头疼...
查看>>
这款超级搜索神器,我爱了!
查看>>
太赞了,RTC 2020 编程挑战赛终于正式开启!
查看>>
不用一行代码,就写了个爬虫!这款谷歌插件已经打包好了!
查看>>
Chrome,你够了!
查看>>
嫌官方文档太烂?TensorFlow 开源工具书,助你快速上手开发!
查看>>
Java 依然很牛逼
查看>>
从罗永浩抖音带货一晚成交 1.1 个亿,我看到了未来应届生这几个新求职机遇......
查看>>
这个 Python 代码自动补全神器搞得我卧槽卧槽的!
查看>>
卧槽!为鼓励民众居家隔离,国外这些计算机学习资源将免费对外开放!
查看>>
Eclipse Theia 1.0 发布,这才是 VS Code 真正的开源替代方案?!
查看>>
堪称开挂!印度裔 00 后 7 岁教人编程,12 岁成 IBM 荣誉顾问,还出过书!
查看>>
为什么魂斗罗只有 128KB 却可以实现那么长的剧情?
查看>>
全球呼吸机告急!医疗科技巨头美敦力 "开源" 设计图和源代码!
查看>>
哇!动辄上千台服务器,到底在干嘛?
查看>>