>>分享数据结构和算法相关的知识和技术 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 19929 个阅读者 刷新本主题
 * 贴子主题:  Binary Search二分查找算法 回复文章 点赞(0)  收藏  
作者:flybird    发表时间:2020-03-15 22:58:07     消息  查看  搜索  好友  邮件  复制  引用

     1. 背景

        Binary Search(二分查找法)也称为折半查找法,用来查找一组有序记录数组中某一项记录。

       其基本思想是:将记录按有序化(递增或递减)排列

        查找过程中用跳跃式方式查找。

                2. 优点

        比较次数少

        查找速度快

        平均性能好

        占用系统内存较少

                3. 缺点

        数据源必须有序(递增或递减)

        插入删除困难

                4. 例子

     例如对于[5、10、19、21、31、37、42、48、50、52]这十个数,从中查找48这条记录,如图

点击在新窗口中浏览原图
CTRL+鼠标滚轮放大或缩小

      从图中可以看出,3次就找到了48这个数。

                    如果是顺序查找,则需要8次。

                    因此二分查找法的效率比顺序查找法要好(平均来说)。

                    顺序查找平均次数为:(1+2+3+4+5+6+7+8+9+10)/10=5.5次

                    二分查找平均次数为:(4+3+2+4+3+1+4+3+2+3)/10 = 2.9次



----------------------------
原文链接:https://blog.51cto.com/lisea/1978038

程序猿的技术大观园:www.javathinker.net



[这个贴子最后由 flybird 在 2020-03-16 11:19:09 重新编辑]
  Java面向对象编程-->接口
  JavaWeb开发-->JSP中使用JavaBean(Ⅱ)
  JSP与Hibernate开发-->Java应用分层架构及软件模型
  Java网络编程-->通过JDBC API访问数据库
  精通Spring-->计算属性和数据监听
  Vue3开发-->绑定CSS样式
  整理得吐血了,二叉树、红黑树、B、B+树超齐全,快速搞定数据...
  LVS的调度算法-个人理解
  HAProxy 之 算法介绍
  浅谈算法,一些感悟
  算法的概念、特征和基本类型简介
  分布式一致Hash算法-存储之道
  Java 选择排序算法
  Citrix Netscaler负载均衡算法
  令牌桶算法
  无向图的最短路径求解算法之——Dijkstra算法
  有趣的位图排序算法
  Java算法题:有关100阶楼梯的算法
  绕圆算法
  为什么要学数据结构?
  小米面试算法题:搜索旋转排序数组
  更多...
 IPIP: 已设置保密
树形列表:   
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。