全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JS数组搜索之折半搜索实现方法分析

本文实例讲述了JS数组搜索之折半搜索实现方法。分享给大家供大家参考,具体如下:

一. 方法原理:

当从一个给定的序列数组arr中, 查找某个特定值value时, 折半搜索法是这样做的:

1. 确定搜索范围的起始点: 起点startIndex = 0, 终点endIndex = arr.length - 1;

2. 根据起始点来确定一个中间点middle = Math.floor((终点 - 起点) / 2);

3. 在startIndex < endIndex的前提下, 比较arr[middle]与value的大小:

(1) arr[middle] < value

调整搜索范围为数组的后半部分, 即startIndex = middle + 1, endIndex = arr.length -1;

(2) arr[middle] > value

调整搜索范围为数组的前半部分, 即startIndex = 0, endIndex = middle - 1;

接着, 重新计算middle, 再比较arr[middle]与value, 直到两者相等或者startIndex >= endIndex.

二. 代码:

// 该例的写法适用于序列为由小到大的数组
function binarySearch(arr, value) {
  var startIndex = 0,
  endIndex = arr.length - 1;
  middle = Math.floor((endIndex - startIndex) / 2);
  while (arr[middle] !== value && startIndex < endIndex) {
    if (arr[middle] > value) {
      endIndex = middle - 1;
    } else if (arr[middle] < value) {
      startIndex = middle + 1;
    }
    middle = Math.floor((endIndex - startIndex) / 2);
  }
  return (arr[middle] !== value) ? -1 : middle;
}

三. 优缺点:

(1) 优点:

每查找一次, 被查找的数组项数量会减少一半, 因此其在性能上要优于线性搜索法(在数组项较多时, 尤其明显);

(2) 缺点:

只适用于序列数组, 在对普通数组使用该方法之前, 需要对数组进行排序

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript排序算法总结》、《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript数组操作技巧总结》、《JavaScript遍历算法与技巧总结》、《JavaScript查找算法技巧总结》及《JavaScript错误与调试技巧总结》

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


# JS  # 数组  # 折半  # 搜索  # JavaScript数组的快速克隆(slice()函数)和数组的排序、乱序和搜索(sort()函数)  # JavaScript中数组的排序、乱序和搜索实现代码  # Javascript实现从小到大的数组转换成二叉搜索树  # JavaScript常用数组元素搜索或过滤的四种方法详解  # javascript中搜索数组的四种方法示例详解  # 适用于  # 起始点  # 相关内容  # 遍历  # 感兴趣  # 数据结构  # 给大家  # 这样做  # 在对  # 更多关于  # 所述  # 程序设计  # 上要  # 小到  # 后半部  # 操作技巧  # 定值  # 前半  # 前提下  # 讲述了 


相关文章: 孙琪峥织梦建站教程如何优化数据库安全?  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?  如何通过智能用户系统一键生成高效建站方案?  宝塔Windows建站如何避免显示默认IIS页面?  如何在云指建站中生成FTP站点?  深圳网站制作培训,深圳哪些招聘网站比较好?  佛山企业网站制作公司有哪些,沟通100网上服务官网?  广州美橙建站如何快速搭建多端合一网站?  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  如何配置FTP站点权限与安全设置?  如何通过万网虚拟主机快速搭建网站?  宝塔建站助手安装配置与建站模板使用全流程解析  如何快速上传建站程序避免常见错误?  制作电商网页,电商供应链怎么做?  Swift中swift中的switch 语句  如何快速搭建高效简练网站?  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  网站制作壁纸教程视频,电脑壁纸网站?  如何选择高效可靠的多用户建站源码资源?  广州顶尖建站服务:企业官网建设与SEO优化一体化方案  建站之星安装路径如何正确选择及配置?  建站主机数据库如何配置才能提升网站性能?  专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?  C#怎么创建控制台应用 C# Console App项目创建方法  制作网站怎么制作,*游戏网站怎么搭建?  香港服务器租用费用高吗?如何避免常见误区?  阿里云网站制作公司,阿里云快速搭建网站好用吗?  网站制作公司,橙子建站是合法的吗?  如何正确选择百度移动适配建站域名?  微信网站制作公司有哪些,民生银行办理公司开户怎么在微信网页上查询进度?  建站上传速度慢?如何优化加速网站加载效率?  如何快速生成橙子建站落地页链接?  GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?  建站之星如何取消后台验证码生成?  制作农业网站的软件,比较好的农业网站推荐一下?  如何在宝塔面板中修改默认建站目录?  一键网站制作软件,义乌购一件代发流程?  建站之星2.7模板:企业网站建设与h5定制设计专题  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  如何在宝塔面板中创建新站点?  中山网站推广排名,中山信息港登录入口?  c# F# 的 MailboxProcessor 和 C# 的 Actor 模型  湖州网站制作公司有哪些,浙江中蓝新能源公司官网?  网站制作公司广州有几家,广州尚艺美发学校网站是多少?  网站设计制作企业有哪些,抖音官网主页怎么设置?  如何在西部数码注册域名并快速搭建网站?  ,怎么在广州志愿者网站注册?  b2c电商网站制作流程,b2c水平综合的电商平台? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。