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

相关文章

C++作用域和标识符查找规则详解

《C++作用域和标识符查找规则详解》在C++中,作用域(Scope)和标识符查找(IdentifierLookup)是理解代码行为的重要概念,本文将详细介绍这些规则,并通过实例来说明它们的工作原理,需... 目录作用域标识符查找规则1. 普通查找(Ordinary Lookup)2. 限定查找(Qualif

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

Java进程CPU使用率过高排查步骤详细讲解

《Java进程CPU使用率过高排查步骤详细讲解》:本文主要介绍Java进程CPU使用率过高排查的相关资料,针对Java进程CPU使用率高的问题,我们可以遵循以下步骤进行排查和优化,文中通过代码介绍... 目录前言一、初步定位问题1.1 确认进程状态1.2 确定Java进程ID1.3 快速生成线程堆栈二、分析

C/C++ chrono简单使用场景示例详解

《C/C++chrono简单使用场景示例详解》:本文主要介绍C/C++chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录chrono使用场景举例1 输出格式化字符串chrono使用场景China编程举例1 输出格式化字符串示

javascript fetch 用法讲解

《javascriptfetch用法讲解》fetch是一个现代化的JavaScriptAPI,用于发送网络请求并获取资源,它是浏览器提供的全局方法,可以替代传统的XMLHttpRequest,这篇... 目录1. 基本语法1.1 语法1.2 示例:简单 GET 请求2. Response 对象3. 配置请求

Java Stream.reduce()方法操作实际案例讲解

《JavaStream.reduce()方法操作实际案例讲解》reduce是JavaStreamAPI中的一个核心操作,用于将流中的元素组合起来产生单个结果,:本文主要介绍JavaStream.... 目录一、reduce的基本概念1. 什么是reduce操作2. reduce方法的三种形式二、reduce

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

CSS引入方式和选择符的讲解和运用小结

《CSS引入方式和选择符的讲解和运用小结》CSS即层叠样式表,是一种用于描述网页文档(如HTML或XML)外观和格式的样式表语言,它主要用于将网页内容的呈现(外观)和结构(内容)分离,从而实现... 目录一、前言二、css 是什么三、CSS 引入方式1、行内样式2、内部样式表3、链入外部样式表四、CSS 选

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

C#实现查找并删除PDF中的空白页面

《C#实现查找并删除PDF中的空白页面》PDF文件中的空白页并不少见,因为它们有可能是作者有意留下的,也有可能是在处理文档时不小心添加的,下面我们来看看如何使用Spire.PDFfor.NET通过C#... 目录安装 Spire.PDF for .NETC# 查找并删除 PDF 文档中的空白页C# 添加与删