Binary298FindTheDuplicatedNumber

这个题目对于Two Pointers, Binary Search 以及 array cycle 都有比较深度的考察. 以后值得反复做, 举一反三.

BinarySearch 方法

主要思想在:
https://discuss.leetcode.com/topic/25580/two-solutions-with-explanation-o-nlog-n-and-o-n-time-o-1-space-without-changing-the-input-array
以及 https://discuss.leetcode.com/topic/25580/two-solutions-with-explanation-o-nlog-n-and-o-n-time-o-1-space-without-changing-the-input-array/11

这两个大同小异. 
我首先用的第一种. 出了很多bug

Bug1 到底哪个和哪个比

主要就是没搞清楚count究竟与mid相比, 还是count与nums[mid]相比, 还是nums[i] nums[mid] 比, 还是nums[i] mid比.

Bug2 返回值究竟是哪个

是返回nums[high] nums[low] 还是low high

Bug3 其实上面没提到一个关键问题

binarySearch在这个题目中, 唯一的sorted array实际上是index, 而mid其实代表的是array里面的数值, 并不是index. 我们只是借用index这个排序好的来分左右而以. 所以, low和high到底代表什么? 而最后应该return什么?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值