二分查找步骤及问题总结
1|0二分查找
参数: 有序数组arr(这里按升序来讲),待搜索的值target
1|1步骤
- 定义左边界left和有边界right
- 获取中间索引(整数)
mid = (left+right)/2
,注意:js只有小数,mid需要再取整 - 中间索引的值arr[mid]与待搜索的值target进行比较
arr[mid] == target
,即为找到,返回中间索引midarr[mid] > target
,说明要搜索的值在mid的左边(降序情况相反),需要去mid的左边找,更改右边界right为mid-1,重新查找arr[mid] < target
,说明要搜索的值在mid的右边(降序情况相反),需要去mid的右边找,更改左边界left为mid+1,重新查找
- 查找(循环)的过程中如果
left > right
说明找不到target,结束查找
根据以上步骤可以写出递归、和非递归两种二分查找的方法
1|2代码实现
1|3整数溢出问题
出现原因:java 中的 int 总共就 32 位,正数上限的情况首位也只能是 0,其他位都可以是 1(就是 2^31-1 的情况)。但是如果正数过大了,例如 2^31,计算机不得不把首位变成 1,把它按照正常的方式输出了(把1作为符号位),于是就成了负的值。
获取中间索引时(left + right) / 2
,如果left和right都特别大,那么就有可能超出整数锁能存储的最大值,从而出现整数溢出问题
如下情况,第二次的mid出现了整数溢出问题
输出
如何避免?
方法一
把求中间值公式改为left - left/2 + right/2
=》left + (right - left)/2
由于两个大值相减(right - left)得到的值较小,就避免了溢出问题
方法二
无符号的右移运算代替除法
(left+right)/2
=》(left+right)>>>1
本来溢出的二进制数符号位为负数,由于进行了移位,就不把最高位当成符号位,就解决了溢出问题
__EOF__

本文作者:秋玻
本文链接:https://www.cnblogs.com/weloe/p/16723894.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
本文链接:https://www.cnblogs.com/weloe/p/16723894.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
分类:
数据结构与算法
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)