news 2026/6/9 18:52:44

折半查找的核心逻辑是基于“数组有序”的前提,通过不断将查找区间缩小一半来高效定位目标值

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
折半查找的核心逻辑是基于“数组有序”的前提,通过不断将查找区间缩小一半来高效定位目标值

折半查找的核心逻辑是基于“数组有序”的前提,通过不断将查找区间缩小一半来高效定位目标值。其基本步骤如下:

  1. 定义查找范围的边界lowhigh,初始为数组首尾下标。
  2. 在每一步中计算中间位置mid = low + (high - low) // 2(避免整数溢出)。
  3. 比较目标值key与中间元素arr[mid]
    • key == arr[mid],查找成功,返回mid
    • key < arr[mid],说明目标在左半区,更新high = mid - 1
    • key > arr[mid],说明目标在右半区,更新low = mid + 1
  4. 重复上述过程,直到low > high时结束循环,表示未找到,返回-1

两种实现方式

(1)迭代版(Bsearch)
defbsearch(arr,key):low,high=0,len(arr)-1whilelow<=high:mid=low+(high-low)//2ifarr[mid]==key:returnmidelifkey<arr[mid]:high=mid-1else:low=mid+1return-1
  • 使用循环控制流程,空间复杂度为O(1)
  • 更适合大规模数据或对栈空间敏感的环境。
(2)递归版(Bsearch_rec)
defbsearch_rec(arr,key,low,high):iflow>high:return-1mid=low+(high-low)//2ifarr[mid]==key:returnmidelifkey<arr[mid]:returnbsearch_rec(arr,key,low,mid-1)else:returnbsearch_rec(arr,key,mid+1,high)
  • 利用函数调用自身实现分治,代码更简洁易懂。
  • 空间复杂度为O(log n),因递归深度约为 log₂n。

折半查找的特点总结

特性描述
前提条件数组必须有序且支持随机访问
时间复杂度O(log n) —— 显著优于顺序查找的 O(n)
空间复杂度迭代:O(1),递归:O(log n)
适用结构数组等连续存储结构;不适用于链表
动态操作不适合频繁插入/删除的场景(维护有序成本高)

折半查找要求数据必须是有序的,是因为其核心逻辑依赖于通过比较中间元素来判断目标值位于左半部分还是右半部分。这种“决策依据”只有在数据有序的前提下才成立。

详细解释:

假设我们有一个数组arr和一个目标值key,折半查找每次都会取中间元素arr[mid]进行比较:

  • 如果key == arr[mid],查找成功;
  • 如果key < arr[mid],则认为key应该出现在mid左侧 ——但这仅在数组有序时才正确
  • 如果key > arr[mid],则认为key应该出现在mid右侧 —— 同样依赖于顺序排列。
举个例子:

无序数组:[5, 2, 9, 1, 7],我们要找key = 3
中间元素是9,由于3 < 9,算法会去左边[5, 2]查找,但实际上3并不在数组中,即使存在也可能被错误地“跳过”。

而如果是有序数组:[1, 2, 5, 7, 9],中间是53 < 5→ 正确进入左半部分[1, 2],继续查找可得结果或确认不存在。

✅ 所以:只有当数组有序时,“小于中间值就一定在左边,大于就在右边”这一推理才成立,否则查找过程将失去正确性。


此外,有序性还保证了以下几点:

  • 每次都能安全地排除一半的数据,确保时间复杂度为 O(log n);
  • 不会出现遗漏或误判的情况。

类比理解:

就像查字典时,你是按字母顺序翻页的。如果字典的单词被打乱了,你就无法通过“当前词太大”来决定往前翻还是往后翻。


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/31 6:59:36

Springboot基于Web的绿色环保网站0z5t9(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。

系统程序文件列表项目功能&#xff1a;用户,产品类别,绿色产品,品牌企业,走进环保,法律法规开题报告内容SpringBoot基于Web的绿色环保网站开题报告一、研究背景与意义1.1 研究背景随着全球环境问题的日益严峻&#xff0c;绿色环保已成为社会发展的核心议题。各国政府、企业及公…

作者头像 李华
网站建设 2026/6/10 15:10:01

AI应用架构师必看:10个AI驱动虚拟艺术的核心架构设计技巧

AI应用架构师必看&#xff1a;10个AI驱动虚拟艺术的核心架构设计技巧 副标题&#xff1a;从模型选型到部署优化&#xff0c;构建高性能虚拟艺术生成系统的实战指南 摘要/引言 随着生成式AI技术的爆发&#xff08;如Stable Diffusion、DALL-E 3、Midjourney&#xff09;&…

作者头像 李华
网站建设 2026/6/10 9:41:51

Cosmos IBC跨链传递Sonic数字人身份数据

Cosmos IBC跨链传递Sonic数字人身份数据 在虚拟偶像直播带货、AI教师授课、数字客服交互日益普及的今天&#xff0c;一个核心问题逐渐浮现&#xff1a;这些由人工智能生成的“数字人”&#xff0c;其身份资产往往被锁死在单一平台中。你在A平台训练好的形象&#xff0c;无法直接…

作者头像 李华
网站建设 2026/6/10 11:45:27

有向网是一种带权的有向图,其中每条边都有一个非负的权值表示从一个顶点到另一个顶点的代价或距离

有向网是一种带权的有向图&#xff0c;其中每条边都有一个非负的权值表示从一个顶点到另一个顶点的代价或距离。图 3-42 (a) 描述了这样的一个有向网&#xff0c;包含顶点 $ v_0 \sim v_5 $&#xff0c;并通过边上的数值标明了各边的权重。其对应的邻接矩阵&#xff08;图 3-42…

作者头像 李华
网站建设 2026/6/10 13:45:08

网盘直链助手需会员?我们提供免费高速下载

网盘直链助手需会员&#xff1f;我们提供免费高速下载 在如今这个内容爆炸的时代&#xff0c;谁还没遇到过“点一下下载&#xff0c;等三分钟加载”的窘境&#xff1f;尤其是当你兴冲冲找到一份心仪资料&#xff0c;结果网盘限速到像蜗牛爬——开会员提速&#xff1f;动辄上百元…

作者头像 李华
网站建设 2026/6/10 11:27:21

Spring:代理模式之静态代理动态代理

前言 其实之前写过类似一篇了&#xff0c;重新具体的总结一下 代理模式 为什么要学习代理模式&#xff1f;因为这就是SpringAOP的底层&#xff01;【SpringAOP 和 SpringMVC】面试必定 代理模式的分欸&#xff1a; 静态代理动态代理 代理的原型&#xff1a;静态代理 角色分析&a…

作者头像 李华