您当前的位置:首页 > 电脑百科 > 程序开发 > 算法

大厂高级程序员必备算法,看似简单的二分查找,您了解多少?

时间:2022-07-04 10:51:09  来源:  作者:程序猿星球

一、基础概念

1、Sorted(单调递增or单调递减)

2、Bounded(存在上下界)

3、Accessible by index(能够通过索引访问,数组适合,but链表不适合)

二分查找是一种在每次比较之后将查找空间一分为二的算法。每次需要查找集合中的索引或元素时,都应该考虑二分查找。如果集合是无序的,我们可以总是在应用二分查找之前先对其进行排序。

二分查找一般由三个主要部分组成:

1、预处理--如果有集合未排序,则进行排序。

2、二分查找--使用循环或递归在每次比较后将查找空间划分为两半

3、后处理--在剩余空间中确定可行的候选者

例如:给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。

示例 1:

输入: nums = [-1,0,3,5,9,12], target = 9
输出: 4
解释: 9 出现在 nums 中并且下标为 4

示例 2:

输入: nums = [-1,0,3,5,9,12], target = 2
输出: -1
解释: 2 不存在 nums 中因此返回 -1

提示:

1、你可以假设 nums 中的所有元素是不重复的。

2、n 将在 [1, 10000]之间。

3、nums 的每个元素都将在 [-9999, 9999]之间。

 

step01: 设定初始值 left和 right:

大厂高级程序员必备算法,看似简单的二分查找,您了解多少?

 

step02: 设定中间指针 mid = left + (right-left)/2:

大厂高级程序员必备算法,看似简单的二分查找,您了解多少?

 

step03:

大厂高级程序员必备算法,看似简单的二分查找,您了解多少?

 

step04:

大厂高级程序员必备算法,看似简单的二分查找,您了解多少?

 

step05:

大厂高级程序员必备算法,看似简单的二分查找,您了解多少?

 

step06:

大厂高级程序员必备算法,看似简单的二分查找,您了解多少?

 

step07:

大厂高级程序员必备算法,看似简单的二分查找,您了解多少?

 

二、通用模版

2.1 模版一

var binarySeach(nums,target){
  if(nums == null|| nums.length ==0){
    return -1;
  }
  let left =0,right=nums.length- 1; //初始条件
  while(left<=right){ //终止条件 left>right
    let mid = Math.floor(left + (right-left)/2); 
    if(nums[mid] == target){ 
      return mid;
    } else if(nums[mid]<target){
      left = mid + 1; //向右查找
    }else{
      right = mid - 1; //向左查找
    }
  }
  return -1;
}

关键属性:

  • 二分查找的最基础和最基本的形式
  • 查找条件可以在不与元素的两侧进行比较的情况下确定(或使用它周围的特定元素)
  • 不需要后处理,因为每一步中,你都在检查是否找到了元素。如果到达末尾,则指导未找到该元素。

2.2 模版二

var binarySeach(nums,target){
  if(nums == null|| nums.length ==0){
    return -1;
  }
  
  let left =0,right=nums.length; //初始条件
  
  while(left<right){ //终止条件 left>=right
    let mid = Math.floor(left + (right-left)/2);  //阻止(left+right)溢出
    if(nums[mid] == target){ 
      return mid;
    } else if(nums[mid]<target){
      left = mid + 1; //向右查找
    }else{
      right = mid; //向左查找
    }
  }
  if(left !=nums.length && nums[left] == target) return left;
  return -1;
}

模版二:是二分查找的高级模板。它用于查找需要访问数组中当前索引及其直接右邻居索引的元素或条件。

关键属性:

  • 一种实现二分查找的高级方法
  • 查找条件需要访问元素的直接右邻居
  • 使用元素的右邻居来确定是否满足条件,并决定是向左还是向右
  • 保证查找空间在每一步中至少有2个元素
  • 需要进行后处理,当你剩下一个元素的时候,循环/递归结束。需要评估剩余元素是否符合条件

2.3 模版三

var binarySeach(nums,target){
  if(nums == null|| nums.length ==0){
    return -1;
  }
  
  let left =0,right=nums.length-1; //初始条件
  
  while(left+1 < right){ //终止条件 left+1 == right
    let mid = Math.floor(left + (right-left)/2);  //阻止(left+right)溢出
    if(nums[mid] == target){ 
      return mid;
    } else if(nums[mid]<target){
      left = mid; //向右查找
    }else{
      right = mid; //向左查找
    }
  }
  if(nums[left] == target) return left;
  if(nums[right] == target) return right;
  return -1;
}

模版3是二分法查找的另一种独特形式。 它用于搜索需要访问当前索引及其在数组中的直接左右邻居索引的元素或条件。

关键属性:

  • 实现二分法查找的另一种方法
  • 搜索条件需要访问元素的直接左右邻居
  • 使用元素的邻居来确定它是向右还是向左
  • 保证查找空间在每个步骤中至少有3个元素
  • 需要进行后处理。当剩下2个元素,循环/递归结束。

2.4、模版分析:

大厂高级程序员必备算法,看似简单的二分查找,您了解多少?

 

这三个模版的不同之处在于:

  • 左、中、右索引的分配
  • 循环或递归终止条件
  • 后处理的必要性

其中模版一和模版三是最常用的, 几乎所有二分查找问题都可以用其中之一亲送实现。 模版二更高级一些, 用于解决某些类型的问题。

这 3 个模板中的每一个都提供了一个特定的用例:

模板 1 (left <= right)

  • 二分查找的最基础和最基本的形式。
  • 查找条件可以在不与元素的两侧进行比较的情况下确定(或使用它周围的特定元素)。
  • 不需要后处理,因为每一步中,你都在检查是否找到了元素。如果到达末尾,则知道未找到该元素。

模板 2 (left < right)

  • 一种实现二分查找的高级方法。
  • 查找条件需要访问元素的直接右邻居。
  • 使用元素的右邻居来确定是否满足条件,并决定是向左还是向右。
  • 保证查找空间在每一步中至少有 2 个元素。
  • 需要进行后处理。 当你剩下 1 个元素时,循环 / 递归结束。 需要评估剩余元素是否符合条件。

模板 3 (left + 1 < right)

  • 实现二分查找的另一种方法。
  • 搜索条件需要访问元素的直接左右邻居。
  • 使用元素的邻居来确定它是向右还是向左。
  • 保证查找空间在每个步骤中至少有 3 个元素。
  • 需要进行后处理。 当剩下 2 个元素时,循环 / 递归结束。 需要评估其余元素是否符合条件。

三、复杂度计算

3.1、时间复杂度

O(log n) :

因为二分查找是通过对查找空间中间的值应用一个条件来操作的,并因此将查找空间折半,在更糟糕的情况下,我们将不得不进行O(log n) 次比较, 其中n是集合中元素的数目。

为什么是log n?

  • 二分查找是通过将现有数组一分为二来执行的
  • 因此,每次调用子例程(或完成一次迭代)时,其大小都会减少到现有部分的一半。
  • 首先N变成 N/2,然后又变成N/4,然后继续下去,直到找到元素或尺寸变为1。
  • 迭代的最大次数是log N(base2)。
第一次: n/2
第二次: n/2^2
第三次: n/2^3
...
第k次: n/2^k
大厂高级程序员必备算法,看似简单的二分查找,您了解多少?

 


大厂高级程序员必备算法,看似简单的二分查找,您了解多少?

 

3.2、空间复杂度

O(1)

虽然二分查找确实需要跟踪 3 个指标,但迭代解决方案通常不需要任何其他额外空间,并且可以直接应用于集合本身,因此需要 O(1) 或常量空间。

四、二分查找的应用

  • 二分调试法

把所有潜在的问题都用类似“数组二分查找”的方式把代码遍历一遍,不断缩小问题的范围,最终找到问题原因。

通过二分法,我们可以快速缩小问题范围,这样一来调试的效率也就上去了。

  • Kafka 采用二分法找数据

二分查找相关系列题:

大厂高级程序员必备算法,看似简单的二分查找,您了解多少?

 



Tags:算法   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
诱导付费、自动扣费……微短剧被质疑借助算法精准“围猎”老年人
诱导付费、自动扣费、重复收费&hellip;&hellip;聚焦身边的消费烦心事⑦丨一些微短剧被质疑借助算法精准“围猎”老年人中工网北京3月31日电(工人日报&mdash;中工网记者刘兵)...【详细内容】
2024-04-01  Search: 算法  点击:(11)  评论:(0)  加入收藏
分析网站SEO快速排名算法对网站具体的影响效果
亲爱的朋友们,今天我想和大家分享一个我们都关心的话题&mdash;&mdash;网站SEO快速排名算法对网站我们身处一个信息爆炸的时代,如何在海量的信息中脱颖而出,成为了一个我们不得...【详细内容】
2024-03-28  Search: 算法  点击:(21)  评论:(0)  加入收藏
当prompt策略遇上分治算法,南加大、微软让大模型炼成「火眼金睛」
近年来,大语言模型(LLMs)由于其通用的问题处理能力而引起了大量的关注。现有研究表明,适当的提示设计(prompt enginerring),例如思维链(Chain-of-Thoughts),可以解锁 LLM 在不同领域的...【详细内容】
2024-03-12  Search: 算法  点击:(21)  评论:(0)  加入收藏
谷歌宣布更新搜索算法:打击AI生成内容,提高搜索结果质量
IT之家 3 月 6 日消息,谷歌于当地时间 5 日发文宣布,针对用户对搜索结果质量下降的反馈,将对算法进行调整,旨在打击 AI 生成的内容以及内容农场等垃圾信息,使用户能够看到更多“...【详细内容】
2024-03-06  Search: 算法  点击:(44)  评论:(0)  加入收藏
小红书、视频号、抖音流量算法解析,干货满满,值得一看!
咱们中国现在可不是一般的牛!网上的网友已经破了十个亿啦!到了这个互联网的新时代,谁有更多的人流量,谁就能赢得更多的掌声哦~抖音、小红书、、视频号,是很多品牌必争的流量洼地...【详细内容】
2024-02-23  Search: 算法  点击:(18)  评论:(0)  加入收藏
雪花算法详解与Java实现:分布式唯一ID生成原理
SnowFlake 算法,是 Twitter 开源的分布式 ID 生成算法。其核心思想就是:使用一个 64 bit 的 long 型的数字作为全局唯一 ID。在分布式系统中的应用十分广泛,且 ID 引入了时间戳...【详细内容】
2024-02-03  Search: 算法  点击:(54)  评论:(0)  加入收藏
简易百科之什么是搜索引擎的PageRank算法?
简易百科之什么是搜索引擎的PageRank算法?在互联网时代,搜索引擎是我们获取信息的重要工具。而PageRank算法则是搜索引擎的核心技术之一,它决定了网页在搜索结果中的排名。那么...【详细内容】
2024-01-24  Search: 算法  点击:(57)  评论:(0)  加入收藏
PageRank算法揭秘:搜索引擎背后的魔法师的工作原理
PageRank(PR)算法是由谷歌创始人之一的拉里&middot;佩奇LarryPage命名的一种衡量网站页面重要性的方法。根据谷歌的说法,PageRank通过计算页面链接的数量和质量来粗略估计分...【详细内容】
2024-01-23  Search: 算法  点击:(46)  评论:(0)  加入收藏
程序开发中常用的十种算法,你用过几种?
当编写程序时,了解和使用不同的算法对解决问题至关重要。以下是C#中常用的10种算法,每个算法都伴随着示例代码和详细说明。1. 冒泡排序 (Bubble Sort):冒泡排序是一种简单的比...【详细内容】
2024-01-17  Search: 算法  点击:(46)  评论:(0)  加入收藏
百度最新的搜索引擎算法是什么样的?
百度搜索引擎算法是百度用来决定网页排名的算法。它是百度搜索技术的核心,也是百度作为全球最大的中文搜索引擎的基石。随着互联网的发展和用户需求的不断变化,百度搜索引擎算...【详细内容】
2024-01-10  Search: 算法  点击:(92)  评论:(0)  加入收藏
▌简易百科推荐
小红书、视频号、抖音流量算法解析,干货满满,值得一看!
咱们中国现在可不是一般的牛!网上的网友已经破了十个亿啦!到了这个互联网的新时代,谁有更多的人流量,谁就能赢得更多的掌声哦~抖音、小红书、、视频号,是很多品牌必争的流量洼地...【详细内容】
2024-02-23  二手车小胖说    Tags:流量算法   点击:(18)  评论:(0)  加入收藏
雪花算法详解与Java实现:分布式唯一ID生成原理
SnowFlake 算法,是 Twitter 开源的分布式 ID 生成算法。其核心思想就是:使用一个 64 bit 的 long 型的数字作为全局唯一 ID。在分布式系统中的应用十分广泛,且 ID 引入了时间戳...【详细内容】
2024-02-03   一安未来  微信公众号  Tags:雪花算法   点击:(54)  评论:(0)  加入收藏
程序开发中常用的十种算法,你用过几种?
当编写程序时,了解和使用不同的算法对解决问题至关重要。以下是C#中常用的10种算法,每个算法都伴随着示例代码和详细说明。1. 冒泡排序 (Bubble Sort):冒泡排序是一种简单的比...【详细内容】
2024-01-17  架构师老卢  今日头条  Tags:算法   点击:(46)  评论:(0)  加入收藏
百度推荐排序技术的思考与实践
本文将分享百度在推荐排序方面的思考与实践。在整个工业界的推广搜场景上,特征设计通常都是采用离散化的设计,需要保证两方面的效果,一方面是记忆,另一方面是泛化。特征都是通过...【详细内容】
2024-01-09  DataFunTalk  微信公众号  Tags:百度推荐   点击:(81)  评论:(0)  加入收藏
什么是布隆过滤器?如何实现布隆过滤器?
以下我们介绍了什么是布隆过滤器?它的使用场景和执行流程,以及在 Redis 中它的使用,那么问题来了,在日常开发中,也就是在 Java 开发中,我们又将如何操作布隆过滤器呢?布隆过滤器(Blo...【详细内容】
2024-01-05  Java中文社群  微信公众号  Tags:布隆过滤器   点击:(94)  评论:(0)  加入收藏
面向推荐系统的深度强化学习算法研究与应用
随着互联网的快速发展,推荐系统在各个领域中扮演着重要的角色。传统的推荐算法在面对大规模、复杂的数据时存在一定的局限性。为了解决这一问题,深度强化学习算法应运而生。本...【详细内容】
2024-01-04  数码小风向    Tags:算法   点击:(106)  评论:(0)  加入收藏
非负矩阵分解算法:从非负数据中提取主题、特征等信息
非负矩阵分解算法(Non-negativeMatrixFactorization,简称NMF)是一种常用的数据分析和特征提取方法,主要用于从非负数据中提取主题、特征等有意义的信息。本文将介绍非负矩阵分解...【详细内容】
2024-01-02  毛晓峰    Tags:算法   点击:(75)  评论:(0)  加入收藏
再谈前端算法,你这回明白了吗?
楔子 -- 青蛙跳台阶一只青蛙一次可以跳上一级台阶,也可以跳上二级台阶,求该青蛙跳上一个n级的台阶总共需要多少种跳法。分析: 当n=1的时候,①只需要跳一次即可;只有一种跳法,即f(...【详细内容】
2023-12-28  前端爱好者  微信公众号  Tags:前端算法   点击:(114)  评论:(0)  加入收藏
三分钟学习二分查找
二分查找是一种在有序数组中查找元素的算法,通过不断将搜索区域分成两半来实现。你可能在日常生活中已经不知不觉地使用了大脑里的二分查找。最常见的例子是在字典中查找一个...【详细内容】
2023-12-22  小技术君  微信公众号  Tags:二分查找   点击:(81)  评论:(0)  加入收藏
强化学习算法在资源调度与优化中的应用
随着云计算和大数据技术的快速发展,资源调度与优化成为了现代计算系统中的重要问题。传统的资源调度算法往往基于静态规则或启发式方法,无法适应动态变化的环境和复杂的任务需...【详细内容】
2023-12-14  职场小达人欢晓    Tags:算法   点击:(169)  评论:(0)  加入收藏
站内最新
站内热门
站内头条