Binary Search:287. Find the Duplicate Number
来源:互联网 发布:sql去重复查询多个字段 编辑:程序博客网 时间:2024/06/05 11:26
大神分析:
这道题给了我们n+1个数,所有的数都在[1, n]区域内,首先让我们证明必定会有一个重复数,这不禁让我想起了小学华罗庚奥数中的抽屉原理(又叫鸽巢原理), 即如果有十个苹果放到九个抽屉里,如果苹果全在抽屉里,则至少有一个抽屉里有两个苹果,这里就不证明了,直接来做题吧。题目要求我们不能改变原数组,即不能给原数组排序,又不能用多余空间,那么哈希表神马的也就不用考虑了,又说时间小于O(n2),也就不能用brute force的方法,那我们也就只能考虑用二分搜索法了,我们在区别[1, n]中搜索,首先求出中点mid,然后遍历整个数组,统计所有小于等于mid的数的个数,如果个数大于mid,则说明重复值在[mid+1, n]之间,反之,重复值应在[1, mid-1]之间,然后依次类推,直到搜索完成,此时的low就是我们要求的重复值,参见代码如下。
class Solution {public: int findDuplicate(vector<int>& nums) { int left = 1, right = nums.size()-1; while(left <= right) { int mid = left + (right - left) / 2; int cnt = 0; for(int a : nums) { if(a <= mid) cnt++; } if(cnt > mid) right = mid - 1; else left = mid + 1; } return left; }};
阅读全文
0 0
- Binary Search:287. Find the Duplicate Number
- 287. Find the Duplicate Number--binary search/快慢指针
- 287. Find the Duplicate Number
- 287. Find the Duplicate Number
- 287. Find the Duplicate Number
- 287. Find the Duplicate Number
- 287. Find the Duplicate Number
- 287. Find the Duplicate Number
- 287. Find the Duplicate Number
- 287. Find the Duplicate Number
- 287. Find the Duplicate Number
- 287. Find the Duplicate Number
- 287.Find the Duplicate Number
- 287. Find the Duplicate Number
- 287. Find the Duplicate Number
- 287. Find the Duplicate Number
- 287. Find the Duplicate Number
- 287. Find the Duplicate Number
- sql-server数据库基础知识五(用户、角色、权限)
- C# 调用showDialog后需要Dispose
- 全面解析JavaScript里的循环方法之forEach,for-in,for-of
- i.MX6Q的qnx调试笔记-qnx的IPL源码分析代码流程分析
- C++实现数组构造的线性表
- Binary Search:287. Find the Duplicate Number
- Shell编程详解
- 2017-2018 ACM-ICPC, NEERC, Southern Subregional Contest F. Lost in Transliteration
- mysql取消一条部分输入的语句
- mybatis-generator-1.3.2 代码生成器
- LightOJ-1253 Misere Nim(Nim求解不正常的博弈)
- yum命令因升级python以及更换Yum源后报错
- QT实现简单的计算器
- instanceof 与isAssignableFrom的区别