二分查找

二分查找(binary search)是一种基于分治策略的高效搜索算法。它利用数据的有序性,每轮缩小一半搜索范围,直至找到目标元素或搜索区间为空为止。

例:给定一个n 的数组 nums ,元素按从小到大的顺序排列且不重复。请查找并返回元素 target 在该数组中的索引。若数组不包含该元素,则返回 −1 。示例如图所示。

如上图所示,我们先初始化指针 i=0 和 j=n−1 ,分别指向数组首元素和尾元素,代表搜索区间 [0,n−1] 。请注意,中括号表示闭区间,其包含边界值本身。

接下来,循环执行以下两步。

  1. 计算中点索引 m= ⌊(i+j)/2⌋,其中 ⌊⌋ 表示向下取整操作。
  2. 判断 nums[m] 和 target 的大小关系,分为以下三种情况。                                                    当 nums[m] < target 时,说明 target 在区间 [m+1,] 中,因此执行 i=m+1 。        当 nums[m] > target 时,说明 target 在区间 [i,m−1] 中,因此执行 j=m−1 。        当 nums[m] = target 时,说明找到 target ,因此返回索引m 。

若数组不包含目标元素,搜索区间最终会缩小为空。此时返回 −1 。

值得注意的是,由于i 和 j 都是 int 类型,因此 i+j 可能会超出 int 类型的取值范围。为了避免大数越界,我们通常采用公式 m=⌊i+(j−i)/2⌋ 来计算中点。

/* 二分查找(双闭区间) */
int binarySearch(vector<int> &nums, int target) {// 初始化双闭区间 [0, n-1] ,即 i, j 分别指向数组首元素、尾元素int i = 0, j = nums.size() - 1;// 循环,当搜索区间为空时跳出(当 i > j 时为空)while (i <= j) {int m = i + (j - i) / 2; // 计算中点索引 mif (nums[m] < target)    // 此情况说明 target 在区间 [m+1, j] 中i = m + 1;else if (nums[m] > target) // 此情况说明 target 在区间 [i, m-1] 中j = m - 1;else // 找到目标元素,返回其索引return m;}// 未找到目标元素,返回 -1return -1;
}

时间复杂度为O(log⁡n) :在二分循环中,区间每轮缩小一半,循环次数为log_{2}n⁡。

空间复杂度为O(1) :指针 i 和 j 使用常数大小空间。

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

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

相关文章

一键转换,创新无限:将HTML轻松转化为PDF!

在数字时代&#xff0c;HTML与PDF已成为信息传递的两大主流格式。然而&#xff0c;在这两者之间转换常常让人感到困扰。现在&#xff0c;有了我们的创新工具&#xff0c;您只需轻点一下&#xff0c;即可一键将HTML转化为PDF&#xff01; 首先&#xff0c;我们要进入首助编辑高…

【产品人卫朋】硬件产品经理:从入门到精通

目录 本文目录 1. 前言说明 2. 内容说明 3. 资料包说明 作者简介 本文目录 1. 前言说明 2. 内容说明 3. 资料包说明 1. 前言说明 本篇内容节选自实体书《硬件产品经理&#xff1a;从入门到精通》。 2. 内容说明 鉴于硬件产品的特殊性&#xff0c;不同产品阶段的时间间…

c++学习:隐式类型转换+explicit关键字+四种类型转换

目录 隐式类型转换 当定义一个字符串类 想新建一个对象有下面几种方式 但我不想用隐式类型转换得方式来新建&#xff0c;因为隐式转换成了分配若干字节的空字符串&#xff0c;容易令人误解&#xff0c;就要在构造函数前面用explicit关键字来修饰 explicit关键字的用途是 …

简述synchronized的实现原理

synchronized是Java中用于实现线程同步的关键字&#xff0c;其实现原理基于JVM的内部机制。当一个线程试图访问一个synchronized代码块时&#xff0c;它必须先获取一个锁。这个锁与对象关联&#xff0c;通常是通过对象的监视器&#xff08;Monitor&#xff09;来实现的。每个Ja…

react输入框检索树形(tree)结构

input搜索框搜索树形子级内容1. input框输入搜索内容2. 获取tree结构数据3. 与tree匹配输入的内容&#xff0c;tree是多维数组&#xff0c;一级一级的对比输入的内容是否匹配&#xff0c;用forEach循环遍历数据&#xff0c;匹配不到在往下找&#xff0c;直到找到为null &#x…

MIT_线性代数笔记:第 25 讲 对称矩阵和正定性

目录 对称矩阵 Symmetric matrices实特征值 Real eigenvalues正定矩阵 Positive definite matrices 对称矩阵是最重要的矩阵之一&#xff0c;其特征值为实数并且拥有一套正交特征向量。正定矩阵的性质则更好。 对称矩阵 Symmetric matrices 包含特殊性质的矩阵&#xff0c;例如…

Probabilistic Forecasting with Temporal Convolutional Neural Network

Abstract 我们提出了一种基于卷积神经网络&#xff08;CNN&#xff09;的概率预测框架&#xff0c;用于多个相关时间序列预测。该框架可用于估计参数和非参数设置下的概率密度。更具体地说&#xff0c;构建基于扩张因果卷积网络的堆叠残差块来捕获序列的时间依赖性。与表示学习…

Certum与Geotrust的SSL证书区别

Certum和GeoTrust都是知名的CA认证机构&#xff0c;这两个品牌下的SSL证书在多个方面存在一些差异。今天就随SSL盾小编了解Certum与Geotrust证书的区别。 一、Certum机构背景 Certum是波兰的一家CA认证机构&#xff0c;成立于2002年&#xff0c;至今已有近20多年的历史。旗下有…

LeetCode-棒球比赛(682)

题目描述&#xff1a; 你现在是一场采用特殊赛制棒球比赛的记录员。这场比赛由若干回合组成&#xff0c;过去几回合的得分可能会影响以后几回合的得分。 比赛开始时&#xff0c;记录是空白的。你会得到一个记录操作的字符串列表 ops&#xff0c;其中 ops[i] 是你需要记录的第…

基于ZU19EG的100G-UDP解决方案

概述 本文档介绍ZU19EG与Mellanox CX6 100G网卡通信解决方案。 环境配置 FPGA硬件&#xff1a;519-ZU19EG的4路100G光纤PCIe加上计算卡 电脑&#xff1a;国产国鑫主板&#xff08;双PCU&#xff09;&#xff1a;Gooxi G2DA-B CPU:Intel Xeon Silver 2.2GHz 内存&#xff1…

Asp .Net Web应用程序(.Net Framework4.8)网站发布到IIS

开启IIS 如果已开启跳过这步 打开控制面板-程序 打开IIS 发布Web程序&#xff08;.Net Framework 4.8 web网页&#xff09; 进入IIS管理器新建一个应用池 新建一个网站 网站创建完毕 为文件夹添加访问权限 如果不添加访问权限&#xff0c;运行时将会得到如下错误 设置权限 勾…

kubernetes ResourceQuotas Limits(资源配额)

开头语 写在前面&#xff1a;如有问题&#xff0c;以你为准&#xff0c; 目前24年应届生&#xff0c;各位大佬轻喷&#xff0c;部分资料与图片来自网络 内容较长&#xff0c;页面右上角目录方便跳转 简介 当多个用户或团队共享具有固定节点数目的集群时&#xff0c;人们会…

如何测试Web网页的兼容性测试?

测试Web网页的兼容性是一个重要的步骤&#xff0c;以确保网站在不同的浏览器、操作系统和设备上都能正常工作。以下是一些步骤和方法来测试网页的兼容性&#xff1a; 01. 确定目标平台 首先&#xff0c;确定要测试的目标浏览器、操作系统和设备。这通常包括最常用的浏览器&…

bbox_to_anchor调整图例位置

ax.legend([box[boxes][0], box[boxes][1], box[boxes][2], box[boxes][3]],[1961-1990, 1971-2000, 1981-2010, 1991-2020], bbox_to_anchor(0.05, 1), locupper left, ncol2)

使用串口 DMA 模式接收不定长数据

一、简介 曾经遇到客户有一个需求&#xff0c;需要用串口 DMA 的方式接收不定长度的数据&#xff0c;DMA 有个缺点就是在每次传输前需要设定好传输的字节长度&#xff0c;这种方式显然对于接收不定长度的数据来说没有那么灵活。但 DMA 也有着显著的优点&#xff0c;如可直接访…

阿里巴巴中国站 1688 商品详情 API 实时数据获取

一、引言 随着电子商务的快速发展&#xff0c;实时数据获取在商业决策中扮演着越来越重要的角色。阿里巴巴中国站作为国内领先的 B2B 平台&#xff0c;提供了丰富的 API 接口供开发者使用。本文将重点介绍如何通过阿里巴巴中国站的 1688 商品详情 API 实现实时数据获取&#x…

JS新手入门笔记整理:对象

对象可以分为两种&#xff1a;一种是“自定义对象”&#xff0c;另外一种是“内置对象”。自定义对象&#xff0c;指的是需要我们自己定义的对象。内置对象&#xff0c;指的是不需要我们自己定义的&#xff08;即系统已经定义好的&#xff09;、可以直接使用的对象。在JavaScri…

abp vnext 下载指定版本的项目

开发环境 Win11 vs2022 abp vnext 下载地址&#xff1a;Get Started | ABP.IO 下载abp框架之前&#xff0c;需要先安装CLI&#xff0c;打开命令提示符&#xff0c;执行以下命令即可&#xff0c;这个也可以指定版本下载&#xff0c;这里就不做介绍了&#xff0c;以及删除命令…

网络协议到底是什么?

本文介绍了通信协议的概念以及如何通过添加特定的机制和信息来确保无错误的数据传输。 1. 通信协议的概念 协议由所有 "交换 "信息的站点使用的通信规则和程序组成。所有在网络上交换数据的站点都使用协议&#xff0c;以满足目标。 协议是一组预定义的规则和约定&am…

【MySQL】数据库之Redis的持久化

目录 一、Redis的高可用 1.1什么是高可用 1.2Redis的高可用技术 1.3持久化功能 1.4Redis持久化的方式 二、Redis的持久化之RDB 2.1RDB持久化的触发方式 触发条件 RDB持久化的触发分为手动触发和自动触发两种。 &#xff08;1&#xff09;手动触发 &#xff08;2&…