5.算法讲解之-二分查找(简单易懂)

2024-06-01 21:12

本文主要是介绍5.算法讲解之-二分查找(简单易懂),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.简介

        1.二分查找的思路简单易懂,较难的是如何处理查找过程中的边界条件,当较长时间没写二分查找的时候就容易忘记如何处理边界条件。

        2.只有多写代码,多做笔记就不易忘记边界条件

2.算法思路

        正常查找都是从头到尾查找一个数字是否在数组中

        二分查找适用于已经有序的数组,利用有序的这个性质,定义两个指针,left指向头,right指向尾,定义一个mid为头尾指针的平均值。

首先选择mid位置的数字和目标值比较

中间值与target相等直接返回这个数字的下标即可

如果不相等

        如果mid位置的数字数字大于目标值,则mid位置的数字向右所有数字都大于target,全部排除,让mid-1变为新的尾部

        如果mid位置的数字数字小于目标值,则mid位置的数字向左所有数字都小于target,全部排除,让mid+1成为新的头部

最后left>right的话说明该数组中没有target这个数字

    示例

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

       

        示例1

         nums=[-1,0,3,5,9,] target=9        输出4,因为数组中有9,且其下标尾4

下面给出查找的过程

mid处为3,3<9,所以让mid+1成为新的头部(left=mid+ 1)

如下图

5<9,再次缩小左边界

找到了,返回mid下标4

        示例2       

        nums=[-1,0,3,5,9,] target=2        输出-1,因为数组中没有2

同理给出过程

3>2,缩小右边界 right=mid-1

此时,新的mid为(0+1)/2=0

-1<2,让left=mid+1

此时0<2,让left=mid+1

left>right.说明整个数组中没有目标值,返回-1

3.实现代码

代码如下

int BinarySearch(vector<int>& arr, int target)
{if (arr.size() < 1)return -1;int left = 0, right =arr.size() - 1;while (left <= right){int mid = left + ((right - left) >> 1);if (arr[mid] > target)right = mid - 1;else if (arr[mid] < target)left = mid + 1;elsereturn mid;}//没找到return -1;
}

4.二分查找的特点

时间复杂度:O(logN)

空间复杂度:O(1)

适用于查找有序的数组

5.简单测试

测试代码

int BinarySearch(vector<int>& arr, int target)
{if (arr.size() < 1)return -1;int left = 0, right =arr.size() - 1;while (left <= right){int mid = left + ((right - left) >> 1);if (arr[mid] > target)right = mid - 1;else if (arr[mid] < target)left = mid + 1;elsereturn mid;}//没找到return -1;
}int main()
{vector<int> arr = { -1,0,3,5,9 };cout << BinarySearch(arr, 9) << endl;cout << BinarySearch(arr, 2) << endl;return 0;
}

测试结果

6.Leetcode相关练习题

704. 二分查找 - 力扣(LeetCode)

35. 搜索插入位置 - 力扣(LeetCode)

367. 有效的完全平方数 - 力扣(LeetCode)

69. x 的平方根 - 力扣(LeetCode)

34. 在排序数组中查找元素的第一个和最后一个位置 - 力扣(LeetCode)

下面这道题思想类似于二分查找,是高频面试题之一

240. 搜索二维矩阵 II - 力扣(LeetCode)

这篇关于5.算法讲解之-二分查找(简单易懂)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1022132

相关文章

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

C++ vector的常见用法超详细讲解

《C++vector的常见用法超详细讲解》:本文主要介绍C++vector的常见用法,包括C++中vector容器的定义、初始化方法、访问元素、常用函数及其时间复杂度,通过代码介绍的非常详细,... 目录1、vector的定义2、vector常用初始化方法1、使编程用花括号直接赋值2、使用圆括号赋值3、ve

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

springboot简单集成Security配置的教程

《springboot简单集成Security配置的教程》:本文主要介绍springboot简单集成Security配置的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录集成Security安全框架引入依赖编写配置类WebSecurityConfig(自定义资源权限规则

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.