二分查找算法实现

本文介绍了二分查找算法的思路,强调了在计算mid时防止溢出的重要性,以及如何正确更新二分区间以避免死循环。文章通过举例说明了当数组元素为1、3、5时查找4的问题,并提出解决方案。同时,提供了两种不同判定条件的二分查找代码实现。
摘要由CSDN通过智能技术生成


思路

  • while判定条件的选择,注意最外层的return的内容就好。下面提供了两个代码版本。
  • 计算 mid 时需要防止溢出(对应类型【如本例中的int】可能存不下),即 mid=left+(right-left)/2。
  • 如何更改二分区间

重点说第三点,一开始的选择是当num在mid左边时直接将mid给right,反之num在mid右边将mid给left。但是这就出现了一个问题。例如:

数组元素为 1 3 5 的时候,如果你想要找4,那么:

  1. 第一次left = 0, right = 2, mid = 1;
  2. 第二次left = 1, right = 2, mid = left+(right-left)/2 = 1。

可以看出mid指向的下标是没有更改的,因此程序会陷入一直以下标1为left、mid,以下标2为right的尴尬情况——死循环。如果只是单纯的将mid的值粗暴的赋给left或者right,是没法解决问题的,因为会在一个重复的区间不断查找——当mid所指向的数组元素不为num时,mid位置已经可以被排除了,其不应该作为下一次

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

·Jormungand

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值