剑指offer(二)不修改数组找出重复数字

示例分析:

例如:12344

数值上是1到4,那么就设置相应的“抽屉”1,2,3,4;

由于数组长度为5,大于“抽屉”数,所以一定有的“抽屉”里放多个数的,也就是对应的重复数字。

那么就可以用“二分”来求解。

解释:

1.  l  = 1, r = 4, nums.size()-1数组长度减1就代表“抽屉”数,l~r,代表了“抽屉”,(这里应该是不允许出现12333这种情况),但是求“抽屉”数也可以找到nums中最大的数字,就是抽屉数

2.  求出数值上的中点mid(2)

3.  遍历nums,统计 >=l 并且 <=mid 的数的个数;这里是扫描了整个nums数组里的数得到的统计结果,其实就是在统计数值上小于等于mid的数的个数

4.  如果s大于左边区间长度,说明左边数字比“抽屉”多,那么一定有重复的,如果小于也可能有重复的,这时这个算法检测不出来。

5.  否则就在右边。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值