二分法查找解题原理与运用方式

简介: 二分法查找解题原理与运用方式

二分法原理


分法查找也可以叫做折半查找;它是一种高效的查找方法。但是它要求线性表必须采用顺序存储结构,而且表中元素是有序排列。

以升序数列为例,比较一个元素与数列中的中间位置的元素的大小,如果比中间位置的元素大,则继续在后半部分的数列中进行二分查找;

如果比中间位置的元素小,则在数列的前半部分进行比较;如果相等,则找到了元素的位置。

每次比较的数列长度都会是之前数列的一半,直到找到相等元素的位置或者最终没有找到要找的元素。


在二分查找中,目标元素的查找区间的定义十分重要,只找对了区间,才能够减少计算找到正确的值

简单来说二分查找有以下几个步骤:


  • 首先选择数组中间的数字和需要查找的目标值比较;如果相等最好,就可以直接返回答案了
  • 如果不相等
  • 如果中间的数字大于目标值,则中间数字向右的所有数字都大于目标值,全部排除
  • 如果中间的数字小于目标值,则中间数字向左的所有数字都小于目标值,全部排除


image.png


时间复杂度


二分查找有个很重要的特点,就是不会查找数列的全部元素,而查找的数据量其实正好符合元素的对数,正常情况下每次查找的元素都在一半一半地减少。

所以二分查找的时间复杂度为

image.png

实战实验


看的再多的理论都是纸上谈兵,我们来实战一下

在有序数组[-1,0,3,4,6,10,13,14]找到13的下标

返回值:6

说明:13 出现在nums中并且下标为 6

具体的解题步骤可以拆分为以下几步:

  • 第一步:初始化区间范围[left,right]
  • 第二步:如果左区间值left小于等于右区间值right;开始进入循环
  • 在循环体内找到中间点;判断中间点的值是不是目标值,如果是就返回
  • 如果目标值 < nums[mid],表示目标值可能在左半边,就重新赋值右区间
  • 如果目标值 > nums[mid],表示目标值可能在右半边,就重新赋值左区间
function search(nums, target) {
    // write code here
    // 在区间[left,right]中查找元素,左闭右闭
    let left = 0;
    let right = nums.length - 1;
    while (left <= right) {
        // 计算中间点
        let mid = parseInt(left + (right-left)/2);
        if (target == nums[mid]) {
            return mid;
         // 如果target < nums[mid],表示目标值可能在左半边
        } else if (target < nums[mid]){
            right = mid - 1;
        // 如果target > nums[mid],表示目标值可能在右半边
        } else if (target > nums[mid]){
            left = mid + 1;
        }
    }
    // 未找到返回-1
    return -1;
}
module.exports = {
  search: search,
};



目录
打赏
0
0
0
0
0
分享
相关文章
Google Earth Engine(GEE)——显示和下载影像出现的问题
Google Earth Engine(GEE)——显示和下载影像出现的问题
261 0
强化学习:蒙特卡罗求解最优状态价值函数——手把手教你入门强化学习(五)
本文介绍了强化学习中的蒙特卡罗算法,包括其基本概念、两种估值方法(首次访问蒙特卡罗与每次访问蒙特卡罗)及增量平均优化方式。蒙特卡罗法是一种基于完整回合采样的无模型学习方法,通过统计经验回报的平均值估计状态或动作价值函数。文章详细讲解了算法流程,并指出其初期方差较大、估值不稳定等缺点。最后对比动态规划,说明了蒙特卡罗法在强化学习中的应用价值。适合初学者理解蒙特卡罗算法的核心思想与实现步骤。
252 4
阿里云服务器租用价格参考:云服务器各收费项目收费标准与活动价格
阿里云服务器收费项目有实例价格、预留实例券、专有宿主机、块存储价格、存储容量单位包、带宽价格和快照服务价格,收费模式有包年包月和按量付费模式。本文为大家汇总了2025年阿里云服务器各个收费项目的最新收费标准与云服务器的最新活动价格,以供参考和了解。
Centos7安装killall,fuser, killall,pstree和pstree.x11
通过上述步骤,您已在CentOS 7系统中成功部署了killall、fuser、pstree以及pstree.x11,为高效管理系统进程打下了坚实基础。更多关于服务器管理与优化的知识,获取全面技术支持与解决方案。
335 1
Python中文词汇与英文词频统计
本文介绍了如何使用Python进行英文和中文词频统计。对于英文,借助内置库按空格分隔单词并处理特殊字符;对于中文,需安装jieba分词库。代码实现中,通过读取文件、分词、统计词频并输出到文件。运行时,通过命令行提供文本和结果文件路径。此技能在学术研究、语言分析和文本挖掘领域颇有价值。
Python中文词汇与英文词频统计
软件体系结构 - 数据分片
【4月更文挑战第20天】软件体系结构 - 数据分片
208 15
解决SpringBoot多模块发布时99%的问题?SpringBoot发布的8个原则和4个问题的解决方案
解决SpringBoot多模块发布时99%的问题?SpringBoot发布的8个原则和4个问题的解决方案
706 0
解决SpringBoot多模块发布时99%的问题?SpringBoot发布的8个原则和4个问题的解决方案
AIGC有效提升病理诊断效率、缩短药品研发周期
【1月更文挑战第18天】AIGC有效提升病理诊断效率、缩短药品研发周期
379 2
AIGC有效提升病理诊断效率、缩短药品研发周期
DataWorks中mongo同步到odps后时间多了8小时?
DataWorks中mongo同步到odps后时间多了8小时?
249 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问