【JavaScript 算法】二分查找:快速定位目标元素


文章目录
- 一、算法原理
- 二、算法实现
- 三、应用场景
- 四、优化与扩展
- 五、总结

二分查找(Binary Search)是一种高效的查找算法,适用于在有序数组中快速定位目标元素。相比于线性查找,二分查找的时间复杂度为 O(log n),具有较高的效率。本文将详细介绍二分查找算法的原理、实现及其应用。
一、算法原理
二分查找通过不断将查找范围减半,从而快速定位目标元素。其基本步骤如下:
- 初始化查找范围为数组的起始索引和结束索引。
- 计算中间索引。
- 将中间索引的元素与目标元素进行比较。
- 如果相等,则找到目标元素,返回其索引。
- 如果目标元素小于中间索引的元素,则将查找范围缩小到左半部分。
- 如果目标元素大于中间索引的元素,则将查找范围缩小到右半部分。
- 重复上述步骤,直到查找范围为空或找到目标元素。

二、算法实现
以下是二分查找的JavaScript实现:
/*** 二分查找算法* @param {number[]} arr - 有序数组* @param {number} target - 目标元素* @return {number} - 目标元素的索引,未找到返回 -1*/
function binarySearch(arr, target) {let left = 0;let right = arr.length - 1;while (left <= right) {const mid = Math.floor((left + right) / 2);if (arr[mid] === target) {return mid; // 找到目标元素} else if (arr[mid] < target) {left = mid + 1; // 查找右半部分} else {right = mid - 1; // 查找左半部分}}return -1; // 未找到目标元素
}// 示例
const arr = [1, 3, 5, 7, 9, 11, 13];
const target = 7;
const index = binarySearch(arr, target);
console.log(index); // 输出: 3
三、应用场景
- 有序数组查找:在有序数组中快速定位元素的位置。
- 求解问题:用于求解某些需要二分查找的算法问题,如寻找数组中的峰值元素。
- 数据分析:在数据分析中,二分查找用于快速查找特定值的位置。
四、优化与扩展
- 递归实现:除了迭代实现外,二分查找也可以用递归方式实现。
/*** 递归实现二分查找算法* @param {number[]} arr - 有序数组* @param {number} target - 目标元素* @param {number} left - 左索引* @param {number} right - 右索引* @return {number} - 目标元素的索引,未找到返回 -1*/
function binarySearchRecursive(arr, target, left = 0, right = arr.length - 1) {if (left > right) {return -1; // 未找到目标元素}const mid = Math.floor((left + right) / 2);if (arr[mid] === target) {return mid; // 找到目标元素} else if (arr[mid] < target) {return binarySearchRecursive(arr, target, mid + 1, right); // 查找右半部分} else {return binarySearchRecursive(arr, target, left, mid - 1); // 查找左半部分}
}// 示例
const indexRecursive = binarySearchRecursive(arr, target);
console.log(indexRecursive); // 输出: 3
- 查找第一个或最后一个出现的位置:通过二分查找,可以扩展算法以查找有序数组中第一个或最后一个目标元素的位置。
五、总结
二分查找是一种高效的查找算法,通过不断将查找范围减半,可以在有序数组中快速定位目标元素。理解和掌握二分查找算法对于解决许多实际问题和优化程序性能都具有重要意义。希望本文对你理解和应用二分查找有所帮助。
相关文章:
【JavaScript 算法】二分查找:快速定位目标元素
🔥 个人主页:空白诗 文章目录 一、算法原理二、算法实现三、应用场景四、优化与扩展五、总结 二分查找(Binary Search)是一种高效的查找算法,适用于在有序数组中快速定位目标元素。相比于线性查找,二分查找…...
论文研读:ViT-V-Net—用于无监督3D医学图像配准的Vision Transformer
目录 摘要 介绍 方法 VIT-V-Net体系结构 损失函数 图像相似性度量 变形场正则化 结果与讨论 摘要 在过去的十年里,卷积神经网络(ConvNets)在各种医学成像应用中占据了主导地位并取得了最先进的性能。然而,由于缺乏对图像中远程空间关系的理解&a…...
C++入门到进阶(图文详解,持续更新中)
C入门到进阶(图文详解,持续更新中) 详解C入门知识到进阶,配合图观看易于理解记录 文章目录 目录 C入门到进阶(图文详解,持续更新中) 文章目录 前言 一、数据 (一)数据类…...
【React Hooks原理 - useRef】
概述 在Function Component项目中当我们需要操作dom的时候,第一时间想到的就是使用useRef这个Hook来绑定dom。但是这个仅仅是使用这个Hook而已,为了更好的学习React Hooks内部实现原理,知其所以然。所以本文根据源码从useRef的基础使用场景一…...
MVC之 IHttpModule管道模型《二》
》》》注意:在http请求的处理过程中,只能调用一个HttpHandler,但可以调用多个HttpModule。 HTTP Modules ASP.NET请求处理过程是基于管道模型的,这个管道模型是由多个HttpModule和HttpHandler组成,当请求到达HttpMod…...
2025上海纺织助剂展会+上海织物整理剂展
2025上海纺织助剂展会上海织物整理剂展 2025第十二届中国(上海)纺织助剂及织物整理剂展览会 时间: 2025年4月23-25日 地点:上海跨国采购会展中心(光复西路2739号) 展会简介: 2025第12届中国(上海&#…...
中科亿海微亮相慕尼黑上海电子展
7月8-10日,备受瞩目的全球电子行业盛会“慕尼黑上海电子展”以空前规模启幕,汇聚了超过1600家参展企业,涵盖了从终端产品制造商到元器件供应商、组装/系统供应商、EMS、ODM/OEM、材料供应商及生产设备供应商的完整产业链。中科亿海微电子科技…...
Spring boot 2.0 升级到 3.3.1 的相关问题 (一)
文章目录 Spring boot 2.0 升级到 3.3.1 的相关问题 (一)拦截器Interceptor的变动问题介绍解决方案 WebMvcConfigurerAdapter 自定义Mvc配置问题介绍解决方案 Spring boot 2.0 升级到 3.3.1 的相关问题 (一) 拦截器Interceptor的…...
数据分析——Python网络爬虫(四){爬虫库的使用}
爬虫库 爬虫的步骤urllib库发送请求两种方法案例 爬虫的步骤 #mermaid-svg-h5azjtPInpsU2ZpP {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-h5azjtPInpsU2ZpP .error-icon{fill:#552222;}#mermaid-svg-h5azjtPInps…...
C++客户端Qt开发——信号和槽
三、信号和槽 1.信号和槽概述 在Qt中,用户和控件的每次交互过程称为一个事件。比如"用户点击按钮”是一个事件,"用户关闭窗口”也是一个事件。每个事件都会发出一个信号,例如用户点击按钮会发出"按钮被点击"的信号&…...
基于双向长短期记忆 BiLSTM 实现股票单变量时间序列预测(PyTorch版)
前言 系列专栏:【深度学习:算法项目实战】✨︎ 涉及医疗健康、财经金融、商业零售、食品饮料、运动健身、交通运输、环境科学、社交媒体以及文本和图像处理等诸多领域,讨论了各种复杂的深度神经网络思想,如卷积神经网络、循环神经网络、生成对…...
微信小程序毕业设计-汽车维修项目管理系统项目开发实战(附源码+论文)
大家好!我是程序猿老A,感谢您阅读本文,欢迎一键三连哦。 💞当前专栏:微信小程序毕业设计 精彩专栏推荐👇🏻👇🏻👇🏻 🎀 Python毕业设计…...
学习大数据DAY16 PLSQL基础语法5
目录 异常 自定义异常的格式 raise_application_error 处理异常 预定义异常 SQLcode和SQLerrm 非预定义异常 作业 触发器 触发器基本概念 DML触发器 DML触发器使用 instead of 触发器 管理触发器 作业2 函数、过程和包 函数 过程 参数 1. in 参数 2.out 参…...
LabVIEW心电信号自动测试系统
开发了一种基于LabVIEW的心电信号自动测试系统,通过LabVIEW开发的上位机软件,实现对心电信号的实时采集、分析和自动化测试。系统包括心电信号采集模块、信号处理模块和自动化测试模块,能够高效、准确地完成心电信号的测量与分析。 硬件系统…...
最值得推荐的10款Windows软件!
AI视频生成:小说文案智能分镜智能识别角色和场景批量Ai绘图自动配音添加音乐一键合成视频播放量破百万https://aitools.jurilu.com/1.音乐播放器——Dopamine Dopamine是一款音乐播放器,设计简洁美观。它支持多种音频格式,包括wav、mp3、ogg…...
游戏视频是后期配音好还是边录边配 游戏视频怎么剪辑制作才能火 视频剪辑免费软件
游戏视频后期配音是先配还是先剪?游戏视频后期配音没有统一的准则,可以先配,也可以后配,主要是根据内容而定。游戏视频剪辑在游戏玩家中十分流行,那么,游戏视频怎么剪辑制作?下面让我们以具体的…...
配置 Node.js 内存限制
配置 Node.js 内存限制 Node.js 应用程序通常需要配置堆内存的大小以优化性能和避免内存溢出问题。你可以通过命令行参数、环境变量或系统属性来设置 Node.js 的内存限制。下面将分别介绍在 Windows、Linux 和 macOS 系统下的配置方法。 Windows 系统 1. 命令行参数方式 在…...
ORA-12518: TNS: 监听程序无法分发客户机连接
ORA-12518: TNS: 监听程序无法分发客户机连接 OracleService 服务停止了,启动就好了...
2.5 计算机网络
声明:文章参考的《系统架构设计师教程(第二版)》,如有侵权,本人将立即修改和删除。 利用通信线路将地理上分散的、具有独立功能的计算机系统和通信设备按不同的形式连接起来,并依靠网络软件以及通信协议实现…...
同三维T80004ESL编码器视频使用操作说明书:高清HDMI编码器,高清SDI编码器,4K超清HDMI编码器,双路4K超高清编码器
同三维T80004ESL编码器视频使用操作说明书:高清HDMI编码器,高清SDI编码器,4K超清HDMI编码器,双路4K超高清编码器 同三维T80004ESL编码器视频使用操作说明书:高清HDMI编码器,高清SDI编码器,4K超清…...
嵌入式文件传输协议:Xmodem/Ymodem原理与应用实践
1. 嵌入式文件传输协议概述在工业控制、航天探测、物联网设备等嵌入式应用场景中,文件传输是最基础也最关键的通信需求之一。从简单的单片机固件升级,到复杂的卫星图像回传,都需要稳定可靠的文件传输机制作为支撑。作为一名嵌入式开发工程师&…...
Pixel Language Portal详细步骤:从GitHub源码构建到自定义16-bit图标替换
Pixel Language Portal详细步骤:从GitHub源码构建到自定义16-bit图标替换 1. 项目介绍与准备工作 Pixel Language Portal(像素语言跨维传送门)是一款基于Tencent Hunyuan-MT-7B翻译引擎构建的创新型翻译工具。它将传统翻译功能与16-bit像素…...
云原生环境中的API网关实践
云原生环境中的API网关实践 🔥 硬核开场 各位技术老铁,今天咱们聊聊云原生环境中的API网关实践。别跟我扯那些理论,直接上干货!在微服务架构中,API网关是整个系统的入口,负责请求路由、负载均衡、安全认证等…...
游戏开发者必备免费源码网,一键搭建
一、全场景覆盖:从休闲小游戏到商业级项目 源码分享网的源码资源库堪称“游戏开发的全家桶”,覆盖了从前端交互到后端逻辑、从移动端到网页端的完整技术栈。无论是想要快速验证创意的休闲小游戏,还是需要搭建商业级游戏平台,这里…...
公开信息整理|2026年3月12日:公积金改革、儿童友好建设、存款利率进入“1时代”与科技突破速览
🔥个人主页:杨利杰YJlio❄️个人专栏:《Sysinternals实战教程》《Windows PowerShell 实战》《WINDOWS教程》《IOS教程》《微信助手》《锤子助手》 《Python》 《Kali Linux》 《那些年未解决的Windows疑难杂症》🌟 让复杂的事情更…...
向量运算的几何奥秘:叉积与点积的混合运算规则解析
1. 从几何视角理解向量运算的本质 第一次接触向量运算时,很多人会被各种公式绕得头晕。其实换个角度看,这些运算规则都对应着直观的几何现象。就像小时候玩积木,看似简单的拼接背后藏着空间结构的奥秘。 点积像是测量两个向量的"重合度&…...
面向商业航天的高可靠电机控制系统:从环境约束到芯片实现
摘要商业航天已成为全球航天产业高质量发展的核心增长极,电机控制系统作为运载火箭、卫星平台、空间载荷与在轨服务装备的关键执行机构,其在轨可靠性、控制精度与环境适应性直接决定航天任务成败。本文系统梳理商业航天电机控制领域的技术演进、典型负载…...
Android Init 系列专题【篇二:Selinux启动流程】
Android Init 系列专题【总篇:深入浅出】https://blog.csdn.net/qq_27672101/article/details/144153376 Android Init 系列专题【篇一:fstab分区表挂载】https://blog.csdn.net/qq_27672101/article/details/146104979 Android Init 系列专题【篇二&a…...
ICLR 2026 | 大模型当裁判也“翻车“?北大清华联合多校提出TrustJudge,让LLM评估更值得信赖
让 GPT-4 给两篇文章打分,A 拿了 4 分、B 拿了 3 分。按常理 A 应该比 B 好吧?但换成成对比较,同一个模型却说 "B 更好"。更离谱的情况也有——A > B > C > A 的"石头剪刀布"循环,连传递性都守不住。…...
内页SEO优化与网站整体优化的关系是什么_网站内页的图片优化需要注意哪些
内页SEO优化与网站整体优化的关系是什么 在当前竞争激烈的互联网环境中,网站的整体优化和内页SEO优化密不可分。内页SEO优化是提升网站整体排名的关键环节,而网站整体优化则为内页SEO提供了坚实的基础。这两者之间的关系可以从多个方面进行探讨…...
