JavaScript折半查找(二分查找)算法原理与实现方法示例


Posted in Javascript onAugust 06, 2018

本文实例讲述了JavaScript折半查找(二分查找)算法原理与实现方法。分享给大家供大家参考,具体如下:

一、问题描述:

在一个升序数组中,使用折半查找得到要查询的值的索引位置。如:

var a=[1,2,3,4,5,6,7,8,9];
search(a,3);//返回2
search(a,1);//左边界,返回0
search(a,9);//右边界,返回8
search(a,0);//比最小的值还小,返回"您查找的数值不存在"
search(a,10);//比最大的值还大,返回"您查找的数值不存在"

注:折半查找必须在有序数组中才有效,无序的数组不能实现查找功能。比如:在[10,5,6,7,8,9,20]中查找10,中间索引位置的值为7,比较得出7比10小,因而应该在右子数组中查找,实际上不可能找到10;

二、我的实现

function search(arr,num) {
  var l=arr.length;
  var left=0;
  var right=l-1;
  var center=Math.floor((left+right)/2);
  while(left<=l-1&&right>=0){
    if (arr[center]==num) return center;
    if (left==right) return "您查找的数不存在";
    if (arr[center]>num) {
      right=center-1;
      center=Math.floor((left+right)/2);
    }else if (arr[center]<num) {
      left=center+1;
      center=Math.floor((left+right)/2);
    }
  }
}
var a=[1,2,3,4,5,6,7,8,9];
console.log(search(a,-2));

说明:

1、基本思路:

每次比较,如果数组中间索引位置的值比要查找的值大,就转而在数组中间位置之前的子数组中查找;相反,如果数组中间索引位置的值比要查找的值大,就转而在数组中间位置之后的子数组中查找;如果数组中间索引位置的值恰好等于要查找的值,就返回该索引位置。

2、left定义查找范围的起始位置,right定义查找范围的结束位置,center定义查找范围的中间位置。

3、while中的逻辑说明:

(1)由于不知道具体查找查找多少次,while是比较好的选择;

(2)循环结束条件:

a、一旦当right小于0时,就不再查找,再纠缠也不会有结果。例如:在a=[1,2,3,4,5,6,7,8,9]中查找0,当查找范围变为left=0,right=0,center=0时,进入while语句,由于arr[center]>0,故执行

right=center-1;
center=Math.floor((left+right)/2);

得到right=-1此时应不再进入循环;

b、一旦当left>l-1时,就不再查找,同样再纠缠也不会有结果。例如:在a=[1,2,3,4,5,6,7,8,9]中查找10,当查找范围变为left=8,right=8,center=8时,进入while语句,由于arr[center]<10,故执行

left=center;
center=Math.floor((left+right)/2);

得到left=9,此时应不再进入循环;

4、始终是通过center匹配到要查找的值;

5、Math.floor处理了查找范围长度为偶数的情况;

6、当left==right了,而arr[center]==num却没执行,可以得出结论查找不到的;

7、当arr[center]==num时,整个函数都结束了,后面语句是不会执行的。

上述代码使用在线HTML/CSS/JavaScript代码运行工具http://tools.3water.com/code/HtmlJsRun测试运行结果如下:

JavaScript折半查找(二分查找)算法原理与实现方法示例

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
JS 在指定数组中随机取出N个不重复的数据
Jun 10 Javascript
jQuery 插件开发指南
Nov 14 Javascript
js正则表达式匹配数字字母下划线等
Apr 14 Javascript
JS+CSS实现自适应选项卡宽度的圆角滑动门效果
Sep 15 Javascript
基于jQuery的Web上传插件Uploadify使用示例
May 19 Javascript
扩展Bootstrap Tooltip插件使其可交互的方法
Nov 07 Javascript
纯JS实现出生日期[年月日]下拉菜单效果
Jun 01 Javascript
对于防止按钮重复点击的尝试详解
Apr 22 Javascript
微信小程序中为什么使用var that=this
Aug 27 Javascript
对Layer UI 模块化的用法详解
Sep 26 Javascript
小程序实现左滑删除的效果的实例代码
Oct 19 Javascript
详解CocosCreator消息分发机制
Apr 16 Javascript
JavaScript插入排序算法原理与实现方法示例
Aug 06 #Javascript
微信小程序之多列表的显示和隐藏功能【附源码】
Aug 06 #Javascript
ES6 系列之 WeakMap的使用示例
Aug 06 #Javascript
JavaScript选择排序算法原理与实现方法示例
Aug 06 #Javascript
ES6 中可以提升幸福度的小功能
Aug 06 #Javascript
原生JS实现的轮播图功能详解
Aug 06 #Javascript
在 Angular6 中使用 HTTP 请求服务端数据的步骤详解
Aug 06 #Javascript
You might like
PHP模拟SQL Server的两个日期处理函数
2006/10/09 PHP
PHP 截取字符串 分别适合GB2312和UTF8编码情况
2009/02/12 PHP
php is_file()和is_dir()用于遍历目录时用法注意事项
2010/03/02 PHP
php从数组中随机抽取一些元素的代码
2012/11/05 PHP
php格式化日期和时间格式化示例分享
2014/02/24 PHP
php导入excel文件到mysql数据库的方法
2015/01/14 PHP
php的无刷新操作实现方法分析
2020/02/28 PHP
基于PHP实现堆排序原理及实例详解
2020/06/19 PHP
javascript中的对象创建 实例附注释
2011/02/08 Javascript
js确认删除对话框效果的示例代码
2014/02/20 Javascript
js轮盘抽奖实例分析
2020/04/17 Javascript
JavaScript学习笔记整理_setTimeout的应用
2016/09/19 Javascript
Angular 4依赖注入学习教程之简介(一)
2017/06/04 Javascript
jQuery事件多次绑定与解绑问题实例分析
2019/02/19 jQuery
element-ui 中使用upload多文件上传只请求一次接口
2019/07/19 Javascript
js瀑布流布局的实现
2020/06/28 Javascript
解决vue 使用setTimeout,离开当前路由setTimeout未销毁的问题
2020/07/21 Javascript
vite2.0+vue3移动端项目实战详解
2021/03/03 Vue.js
python练习程序批量修改文件名
2014/01/16 Python
用Python创建声明性迷你语言的教程
2015/04/13 Python
关于Python 3中print函数的换行详解
2017/08/08 Python
深入理解Django中内置的用户认证
2017/10/06 Python
使用Python抓取豆瓣影评数据的方法
2018/10/17 Python
python3.6+selenium实现操作Frame中的页面元素
2019/07/16 Python
python+logging+yaml实现日志分割
2019/07/22 Python
pycharm快捷键汇总
2020/02/14 Python
Python函数参数分类原理详解
2020/05/28 Python
解决html5中video标签无法播放mp4问题的办法
2017/05/07 HTML / CSS
如何避免常见的6种HTML5错误用法
2017/11/06 HTML / CSS
使用PDF.JS插件在HTML中预览PDF文件的方法
2018/08/29 HTML / CSS
巴黎卡诗美国官方网站:始于1964年的头发头皮护理专家
2017/07/10 全球购物
光声世纪笔试题目
2012/08/25 面试题
医校毕业生自我鉴定
2014/01/25 职场文书
英语感谢信范文
2015/01/20 职场文书
开学随笔
2015/08/15 职场文书
2019年最新七夕唯美祝福语(60条)
2019/07/22 职场文书