关于二分法的理解(以JS为例)

news2025/1/15 19:56:49

算法介绍

基本概念

二分查找算法,又称折半查找算法,是一种在有序数组中查找特定元素的高效方法。它的核心思想是将数组分成两半,然后根据目标值与中间元素的比较结果来决定是继续在左半部分还是右半部分进行搜索。

工作原理
  1. 初始化:设置两个指针,一个指向数组的起始位置(low),另一个指向数组的结束位置(high)。
  2. 循环:当low指针小于或等于high指针时,执行以下步骤:
    • 计算中间位置(mid),通常使用(low + high) / 2
    • 比较中间元素(arr[mid])与目标值。
    • 如果中间元素等于目标值,返回中间位置,查找成功。
    • 如果中间元素大于目标值,说明目标值位于数组的左半部分,更新high指针为mid - 1。
    • 如果中间元素小于目标值,说明目标值位于数组的右半部分,更新low指针为mid + 1。
  3. 结束条件:当low指针大于high指针时,循环结束,表示目标值不在数组中。
时间复杂度

二分查找算法的时间复杂度为O(log n),其中n是数组的长度。这是因为每次迭代都会将搜索范围减半,因此需要对数级次迭代才能找到目标值或确定它不存在。

空间复杂度

二分查找算法的空间复杂度为O(1),因为它只需要常数级别的额外空间来存储索引。

适用条件

二分查找算法要求数组必须是有序的。如果数组是无序的,那么在应用二分查找之前,需要先对其进行排序,这将增加算法的总体时间复杂度。

优点
  • 高效:对于大型数据集,二分查找比线性搜索更快。
  • 简单:算法逻辑清晰,易于理解和实现。
局限性
  • 需要有序数组:如果数组无序,需要先排序,这可能会影响性能。
  • 不适用于动态数据集:如果数组经常变动,维护其有序状态可能会很复杂。

通俗讲解

二分查找算法:就像在书架上找书

想象一下,你在一个按字母顺序排列的书架上找一本特定的书。书架上有成千上万本书,但它们都是有序排列的。二分查找算法就像是你快速找到这本书的方法。

  1. 开始搜索:你站在书架的中间,看看那里的书是不是你要找的。
  2. 缩小范围:如果那本书的书名比你要找的书的书名要早,你就会往右边看。如果晚,就往左边看。
  3. 重复过程:不管你往左还是往右,你都会再次站在新的中间位置,重复刚才的比较过程。
  4. 直到找到:这个过程会一直重复,直到你找到那本书,或者确定书架上没有这本书。

为什么它这么快?

  • 分而治之:每次你只需要看一半的书,而不是全部。这就像是你每次翻页都跳过一半的内容,大大加快了查找速度。
  • 对数级速度:因为每次你都在减少一半的搜索范围,所以查找的速度非常快。这就是为什么我们说它的时间复杂度是O(log n),n是书的数量。想象一下,1000本书,你可能只需要10次就能找到,而不是1000次。

但是,有个前提

  • 书架要有序:这个方法只有在书架上的书籍是有序排列的情况下才有效。如果书架乱七八糟,这个方法就不管用了。

用在计算机上

在计算机科学中,二分查找算法用在有序数组中查找特定元素。计算机就像你一样,通过比较中间的元素和它要查找的目标值,然后决定是继续在数组的哪一半查找,直到找到目标或者确定它不存在。

总结

二分查找算法就像是在有序的书架上快速找到一本书的技巧。它简单、高效,但需要一个有序的环境。下次当你需要在大量有序的数据中快速找到某个元素时,不妨想想这个算法,它可能会帮你节省很多时间。

核心思想

  1. 有序性:二分查找算法的基础是数据的有序性。只有当数据集(如数组)是有序的,算法才能有效工作。

  2. 中间点:算法通过计算数组中间的索引来找到一个参考点,即中间元素。

  3. 比较与决策:将目标值与中间元素进行比较。根据比较结果,算法决定是继续在当前搜索区间的左侧还是右侧进行查找。

  4. 区间减半:无论比较结果如何,都会将搜索范围缩小到原来的一半。如果目标值小于中间元素,搜索区间将变为左侧一半;如果目标值大于中间元素,搜索区间将变为右侧一半。

  5. 迭代:这个过程会不断重复,每次迭代都会更新搜索区间的边界,直到找到目标值或搜索区间为空。

  6. 效率:通过每次迭代将搜索区间减半,二分查找算法能够非常快速地定位元素或确定元素不存在,其效率远高于线性搜索。

  7. 终止条件:搜索终止的条件有两个:找到目标值或搜索区间为空(即low指针大于high指针)。

  8. 简单性:算法的逻辑简单明了,易于实现和理解。

  9. 普适性:虽然二分查找算法在数组上最为常见,但其核心思想可以应用于其他有序数据结构的搜索问题。

  10. 局限性:算法的局限性在于它要求数据必须是事先排序的。如果数据动态变化,需要重新排序,这可能会影响算法的效率。

具体实现(以LeeCode 704题为例)

题目:

答案:

你学废了吗

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1827408.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

编译安装qemu-devel @FreeBSD

缘起 使用cbsd创建riscv jail的时候提示: you have no qemu-user, please install qemu-devle with BSD_USER and STATIC ops (emulators/qemu-devel) 使用pkg安装之后,创建的riscv jail启动报错: Starting jail: fbriscv, parallel timeo…

【猫狗分类】Pytorch VGG16 实现猫狗分类2-模型构建

背景 数据处理做好了,现在搭建网络 声明:整个数据和代码来自于b站,链接:使用pytorch框架手把手教你利用VGG16网络编写猫狗分类程序_哔哩哔哩_bilibili 我做了复现,并且记录了自己在做这个项目分类时候,一…

【回文 马拉车】214. 最短回文串

本文涉及知识点 回文 马拉车 LeetCode214. 最短回文串 给定一个字符串 s,你可以通过在字符串前面添加字符将其转换为回文串。找到并返回可以用这种方式转换的最短回文串。 示例 1: 输入:s “aacecaaa” 输出:“aaacecaaa” 示…

string类的使用手册

1.构造函数 补充:npos:size_t类型数据的最大值 default (1) string(); 构造空的string类对象 copy (2) string (const string& str); 拷贝构造函数(深拷贝) substring (3) string (const string& str, size_t pos, size_…

python 实现各种数据分析方法

1、相关性分析 1.1、https://zhuanlan.zhihu.com/p/669355778https://zhuanlan.zhihu.com/p/669355778

【AI学习】Together AI的新研究:Together MoA(Mixture of Agents)

第一次听说Mixture of Agents,原来Agent也能混合,有意思! 介绍 Together AI的最新研究“Together MoA”(Mixture of Agents,代理混合)是一种创新的方法,旨在通过结合多个开源大型语言模型&…

Postman使用教程(Postman详细图文教程)

本文讲解的是postman工具安装、postman安装教程、postman工具下载、postman使用教程。Postman使得得开发人员和测试人员能够更高效地与Web服务进行交互和调试。 Postman不仅支持常见的HTTP方法,如GET、POST、PUT、DELETE等,还提供了丰富的请求编辑功能&…

Linux---防火墙

文章目录 目录 文章目录 前言 一.静态防火墙:iptables iptables五链 iptables 四表 iptables控制类型 iptables命令配置 前言 这儿主要介绍Linux系统本身提供的软件防火墙的功能,即数据包过滤机制。 数据包过滤,也就是分析进入主机的网络数…

Ubuntu20.04配置ORBSLAM2并在kitti数据集序列进行实验

一、ORB-SLAM2 安装和编译 1.ORB-SLAM2下载 用以下命令在终端上下载 git clone https://github.com/raulmur/ORB_SLAM2 2.安装Pangolin 在下载了ZIP压缩包后解压缩放在ubantu的/home下(此处只要是英文路径都可以),但别急着安装Pangolin我…

STM32项目分享:智慧农业(机智云)系统

目录 一、前言 二、项目简介 1.功能详解 2.主要器件 三、原理图设计 四、PCB硬件设计 1.PCB图 2.PCB板打样焊接图 五、程序设计 六、实验效果 七、资料内容 项目分享 一、前言 项目成品图片: 哔哩哔哩视频链接: https://www.bilibili.c…

PCIe总线-RK3588 PCIe子系统简介(八)

1.PCIe子系统 RK3588 PCIe子系统如下图所示。总共拥有5个PCIe控制器。PCIe30X4(4L)支持RC和EP模式,其他4个仅支持RC模式。ITS port 1连接PCIe30X4(4L)和PCIe30X2(2L)控制器,PCIe30X4(4L)和PCIe30X2(2L)控制器使用PCIe3.0 PIPE PHY。ITS port 0连接PCIe3…

mysql:简单理解mysql mvcc的可重复读

# 原理 假设有这样的sql begin select(或update、insert、delete) ... commit当执行【begin】的时候,标记有一个新事务要开始,但是事务还没有真正开始,事务id还没有产生当执行事务里面的第一个sql语句时(…

VCG显示——汉字,数字,图像

详细的介绍资料: 【从零开始走进FPGA】 玩转VGA http://www.cnblogs.com/spartan/archive/2011/08/16/2140546.html 【FPGA实验】基于DE2-115平台的VGA显示_vga接口实验 de2-115-CSDN博客 【FPGA】VGA显示文字、彩条、图片——基于DE2-115-CSDN博客 一.VCG原理 1.1…

区块链中的gas与转账收款相关概念

区块链是一个经济系统 计算与存储系统都是稀缺的,区块链的工作需要消耗资源共识、trustless需要矿工的工作,而矿工需要激励Transaction的执行有成本(gas),gas费成为矿工的奖励ether是这个经济生态系统的通行货币 关心的问题 合…

Stable Diffusion vs DALL·E3

大模型技术论文不断,每个月总会新增上千篇。本专栏精选论文重点解读,主题还是围绕着行业实践和工程量产。若在某个环节出现卡点,可以回到大模型必备腔调或者LLM背后的基础模型新阅读。而最新科技(Mamba,xLSTM,KAN)则提…

父亲节:我要做爸爸的健康监督员

父亲节将至,总想着能为爸爸做些什么,来表达我们的感激与关爱。在这个特殊的日子里,成为爸爸的健康监督员,用华为 Watch 4 的智慧健康功能,任何时刻都可以关注爸爸的健康状况,放心又安心了。 用一键微体检…

C++ 50 之 继承中的对象模型

继承中的对象模型 在C编译器的内部可以理解为结构体&#xff0c;子类是由父类成员叠加子类新成员而成&#xff1a; #include <iostream> #include <string> using namespace std;class Base03{ public:int m_a; protected:int m_b; private:int m_c; // 哪怕是…

DNS域名解析----分离解析、多域名解析、父域与子域

1 理论部分 1.1 分离解析 DNS的分离解析&#xff0c;是指根据不同的客户端提供不同的域名解析记录。来自不同地址的客户机请求解析同一域名时&#xff0c;为其提供不同的解析结果。也就是内外网客户请求访问相同的域名时&#xff0c;能解析出不同的IP地址&#xff0c;实现负载…

汇编:Linux汇编基本框架与系统调用

在Linux操作系统下进行汇编编程时&#xff0c;基本的汇编程序框架通常包括以下几个部分&#xff1a; ①全局段声明&#xff08;section declarations&#xff09;&#xff1a;定义数据段、代码段等。 ②入口点&#xff08;entry point&#xff09;&#xff1a;程序的执行起点…

Python 显示笔记本电脑的电池状态和百分比

方法一&#xff1a; import psutil import psutil battery psutil.sensors_battery() if battery is None:print("No battery is found.")exit() print (battery) percentagebattery.percent print(f"Battery Percentage: {percentage}%")Battery的信息…