当前位置: 首页 > news >正文

Leedcode 二分查找 理解1

一个up的理解

一、二分查找基础例题

力扣https://leetcode.cn/problems/binary-search/

二、二分查找模板问题

带搜索区间分为3个部分:

1、[mid],直接返回 

2、[left,mid-1],设置边界right = mid - 1

3、[mid+1,right],设置边界left = mid + 1

三、二分查找法的另一种思路

  • 排除法:考虑中间元素nums[mid]在什么情况下不是目标元素
  • 思路:把待搜索区间分为两部分,一部分一定不存在目标元素,另一部分可能存在目标元素,根据中间元素mid被分到左边区间还是右边区间,有以下两种情况。

 四、用“排除法”(减治思想)写二分查找问题的一般步骤:

1、把循环终止的条件写成while(left<right);

2、写if和else语句的时候,思考当nums[mid]满足什么性质时,nums[mid]不是目标元素,接着判断mid的左边有没有可能存在目标元素,mid的右边有没有可能存在目标元素。

3、根据“边界收缩的行为”修改取中间数的行为(重难点)

(1)int mid = (left+right)/2;在left和right较大的时候会发生整形溢出。

        建议的写法:int mid = left + (right - left)/ 2

(2)“/”是整数除法,默认的取整行为是下取整,那么它会带来一个问题;

        int mid = left + (right - left)/ 2;永远取不到有边界right

        在面对left = mid 和 right = mid - 1这种边界收缩行为时,就有可能产生死循环。

死循环:left一直指向0,right一直指向1

4、退出循环以后,看是否需要对num[left]是否是目标元素再做一次检查。

第二个up的理解

https://leetcode.cn/problems/binary-search/solution/er-fen-cha-zhao-xiang-jie-by-labuladong/

写的很详细,我这里展示三种情况的二分查找算法。

第一个,最基本的二分查找算法

因为我们初始化 right = nums.length - 1
所以决定了我们的「搜索区间」是 [left, right]
所以决定了 while (left <= right)
同时也决定了 left = mid+1 和 right = mid-1因为我们只需找到一个 target 的索引即可
所以当 nums[mid] == target 时可以立即返回

第二个,寻找左侧边界的二分查找

因为我们初始化 right = nums.length
所以决定了我们的「搜索区间」是 [left, right)
所以决定了 while (left < right)
同时也决定了 left = mid + 1 和 right = mid因为我们需找到 target 的最左侧索引
所以当 nums[mid] == target 时不要立即返回
而要收紧右侧边界以锁定左侧边界

第三个,寻找右侧边界的二分查找

因为我们初始化 right = nums.length
所以决定了我们的「搜索区间」是 [left, right)
所以决定了 while (left < right)
同时也决定了 left = mid + 1 和 right = mid因为我们需找到 target 的最右侧索引
所以当 nums[mid] == target 时不要立即返回
而要收紧左侧边界以锁定右侧边界又因为收紧左侧边界时必须 left = mid + 1
所以最后无论返回 left 还是 right,必须减一

对于寻找左右边界的二分搜索,常见的手法是使用左闭右开的「搜索区间」,我们还根据逻辑将「搜索区间」全都统一成了两端都闭,便于记忆,只要修改两处即可变化出三种写法:

int binary_search(int[] nums, int target) {int left = 0, right = nums.length - 1; while(left <= right) {int mid = left + (right - left) / 2;if (nums[mid] < target) {left = mid + 1;} else if (nums[mid] > target) {right = mid - 1; } else if(nums[mid] == target) {// 直接返回return mid;}}// 直接返回return -1;
}int left_bound(int[] nums, int target) {int left = 0, right = nums.length - 1;while (left <= right) {int mid = left + (right - left) / 2;if (nums[mid] < target) {left = mid + 1;} else if (nums[mid] > target) {right = mid - 1;} else if (nums[mid] == target) {// 别返回,锁定左侧边界right = mid - 1;}}// 最后要检查 left 越界的情况if (left >= nums.length || nums[left] != target)return -1;return left;
}int right_bound(int[] nums, int target) {int left = 0, right = nums.length - 1;while (left <= right) {int mid = left + (right - left) / 2;if (nums[mid] < target) {left = mid + 1;} else if (nums[mid] > target) {right = mid - 1;} else if (nums[mid] == target) {// 别返回,锁定右侧边界left = mid + 1;}}// 最后要检查 right 越界的情况if (right < 0 || nums[right] != target)return -1;return right;
}

如果以上内容你都能理解,那么恭喜你,二分查找算法的细节不过如此。

通过本文,你学会了:

1、分析二分查找代码时,不要出现 else,全部展开成 else if 方便理解。

2、注意「搜索区间」和 while 的终止条件,如果存在漏掉的元素,记得在最后检查。

3、如需定义左闭右开的「搜索区间」搜索左右边界,只要在 nums[mid] == target 时做修改即可,搜索右侧时需要减一。

4、如果将「搜索区间」全都统一成两端都闭,好记,只要稍改 nums[mid] == target 条件处的代码和返回的逻辑即可,推荐拿小本本记下,作为二分搜索模板。

例题:

题目:

给定一个 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]之间。

通过次数901,475提交次数1,654,035

第一个,最基本的二分查找算法:

class Solution(object):def search(self, nums, target):""":type nums: List[int]:type target: int:rtype: int"""left = 0right = len(nums)-1while left <= right:mid = left + (right - left)//2if nums[mid] < target:left = mid + 1elif nums[mid] > target:right = mid - 1elif nums[mid] == target:return mid    return -1

第二个,寻找左侧边界的二分搜索:

class Solution(object):def search(self, nums, target):""":type nums: List[int]:type target: int:rtype: int"""left = 0right = len(nums)-1while left <= right:mid = left + (right - left)//2if nums[mid] < target:left = mid + 1elif nums[mid] > target:right = mid - 1elif nums[mid] == target:right = mid - 1if left >= len(nums) or nums[left] != target:return -1return left

第三个,寻找右侧边界的二分查找

class Solution(object):def search(self, nums, target):""":type nums: List[int]:type target: int:rtype: int"""left = 0right = len(nums)-1while left <= right:mid = left + (right - left)//2if nums[mid] < target:left = mid + 1elif nums[mid] > target:right = mid - 1elif nums[mid] == target:left = mid + 1if right < 0 or nums[right]!=target:   return -1return right

相关文章:

Leedcode 二分查找 理解1

一个up的理解 一、二分查找基础例题 力扣https://leetcode.cn/problems/binary-search/ 二、二分查找模板问题 带搜索区间分为3个部分&#xff1a; 1、[mid]&#xff0c;直接返回 2、[left&#xff0c;mid-1]&#xff0c;设置边界right mid - 1 3、[mid1,right]&#x…...

【告别篇】大家好,再见了,我转行了,在筹备创业

前言 相信大家也一直看到我的博客没有更新过了&#xff0c;我其实很久没有打开过博客了&#xff0c;也就意味着我很长一段时间都在停滞不前&#xff0c;没有了学习的动力。 现在我上来是想跟大家告个别 &#xff1a; 很多粉丝宝宝的私信我看了&#xff0c;但是没有回&#xf…...

Java——岛屿数量

题目链接 leetcode在线oj题——岛屿数量 题目描述 给你一个由 ‘1’&#xff08;陆地&#xff09;和 ‘0’&#xff08;水&#xff09;组成的的二维网格&#xff0c;请你计算网格中岛屿的数量。 岛屿总是被水包围&#xff0c;并且每座岛屿只能由水平方向和/或竖直方向上相…...

《代码整洁之道》笔记

1章&#xff1a;专业人士要有专业人士素养&#xff0c;要有责任心&#xff0c;编写代码尽可能完善没有bug&#xff0c;有bug也要勇于承担。坚持学习&#xff0c;坚持练习&#xff0c;保证自己的专业技能。谦虚&#xff0c;相互学习&#xff0c;与顾客达成一致2章&#xff1a;说…...

个人网站如何集成QQ快捷登录功能?

目录 一、网站集成QQ快捷登录的好处 二、网站接入QQ快捷登录具体步骤 &#xff08;1&#xff09;登录到QQ互联官网 &#xff08;2&#xff09;进行个人开发者认证 &#xff08;3&#xff09;创建网站应用 &#xff08;4&#xff09;填写网站资料 三、如何在本地开发环境…...

从工厂打螺丝到月薪18k测试工程师,我该满足吗?

以前我比较喜欢小米那句“永远相信美好的事情即将发生”&#xff0c;后来发现如果不努力不可能有美好的事情发生&#xff01;01高中毕业进厂5年&#xff0c;创业经商多次战败&#xff0c;为了生计辗转奔波高中毕业后我就进了工厂&#xff0c;第一份工作是做模具加工。从500元一…...

【相关分析-高阶绘图】MATLAB实现皮尔逊相关分析-散点直方图

虽然皮尔逊相关分析很常见,但如何更好的展现相关性、散点分布、柱状分布,以提升研究结果的美感和冲击感呢?本文拟通过MATLAB绘制包含散点分布、柱状分布、线性展示的散点直方图,有助于审稿人眼前一亮。 1、Pearson相关系数原理 Pearson相关系数(Pearson Correlation Co…...

Spark性能优化二 Shuffle机制分析

&#xff08;一&#xff09; 什么情况下发生shuffle 在MapReduce框架中&#xff0c;Shuffle是连接Map和Reduce之间的桥梁&#xff0c;Map阶段通过shuffle读取数据并输出到对应的Reduce&#xff1b;而Reduce阶段负责从Map端拉取数据并进行计算。在整个shuffle过程中&#xff0c…...

软测入门(四)Appium-APP移动测试基础

Appium 用来测试手机程序。 测试方面&#xff1a; 功能测试安装卸载测试升级测试兼容测试 Android系统版本不同分辨率不同网络 网络切换、中断测试使用中来电话、短信横竖屏切换 环境搭建 Java安装&#xff08;查资料&#xff09;Android SDK安装&#xff0c;配置 HOME和P…...

华为OD机试用Python实现 -【集五福】 |老题且简单

华为OD机试题 最近更新的博客华为 OD 机试 300 题大纲集五福题目描述输入描述输出描述示例一输入输出示例二输入输出代码编写思路Python 代码最近更新的博客 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典...

Typro使用以及安装教程来啦

Typora是一款轻便简洁的Markdown编辑器&#xff0c;支持即时渲染技术&#xff0c;这也是与其他Markdown编辑器最显著的区别。即时渲染使得你写Markdown就想是写Word文档一样流畅自如&#xff0c;不像其他编辑器的有编辑栏和显示栏。今天为大家分享下有关Typroa的安装以及使用&a…...

武汉凯迪正大KD305系列智能数字绝缘电阻测试仪

一、概述 KD305系列智能数字绝缘电阻测试仪采用嵌入式工业单片机实时操作系统&#xff0c;数字模拟指针与数字段码显示结合&#xff0c;该系列表具有多种电压输出等级&#xff08;500V、1000V、2500V、5000V、10000V&#xff09;、容量大、抗干扰强、模拟指针与数字同步显示、交…...

如何使用码匠连接 Redis

目录 在码匠中集成 Redis 在码匠中使用 Redis 关于码匠 Redis 是由 Salvatore Sanfilippo 用 C 语言开发的一款开源的、高性能的键值对存储数据库&#xff0c;它采用 BSD 协议&#xff0c;为了适应不同场景下的存储需求&#xff0c;提供了多种键值数据类型。到目前为止&…...

防止网络攻击的10大网络安全措施

网络攻击每天都在发生。事实上,每天有超2000次的攻击是针对连接了互联网且未受保护的系统,大概每39s就会发生一次。网络攻击导致的数据泄露、敏感信息被盗、财务损失、声誉受损都给企业及个人带来威胁。随着各大企业对数字系统的依赖,网络威胁已成为当下面临的主要挑战。 实…...

LeetCode 面试题 05.02. 二进制数转字符串

【LetMeFly】面试题 05.02.二进制数转字符串 力扣题目链接&#xff1a;https://leetcode.cn/problems/bianry-number-to-string-lcci/ 二进制数转字符串。给定一个介于0和1之间的实数&#xff08;如0.72&#xff09;&#xff0c;类型为double&#xff0c;打印它的二进制表达式…...

[MatLab]图像绘制

一、绘制二维图像 1.一张图上绘制一条线 绘制代码如下面所示&#xff1a; x 0:0.01:2*pi; y sin(x); figure %建立幕布 plot(x,y) %绘制图像 %设置图像属性 title(ysin(x)) xlabel(x) ylabel(y)xlim([0 2*pi]) %限制x轴的值域 自定义图线的颜色…...

datax导入到hive的数据量翻倍

现象 mysql->hive 或者oracle->hdfs 源表数据100w 结果hive表数据200w。 这个现象很容易发生&#xff0c;只要你同一时间调度这个json两次。 原因 "writeMode" : "append", "nonconflict","truncate" * append&#xff…...

拿下3个大厂offer的软件测试面试宝典,面试一文搞定

我是谁、工作几年、你上家公司做什么、负责什么、你的优势、为什么适合这个职位、我想做什么、在这个职位上想得到什么 【呕心沥血】耗时7天整理的金三银四必看的软件测试频面试题 涵盖 接口自动化测试框架面试题_哔哩哔哩_bilibili【呕心沥血】耗时7天整理的金三银四必看的软…...

长短记忆神经网络(LSTM,Long Short-Term Memory)

长短记忆神经网络定义 长短记忆神经网络&#xff08;Long-short term memory, LSTM&#xff09;是一种特殊的RNN结构。该神经网络可以有效保留历史信息&#xff0c;实现对文本的长期依赖信息进行学习。 关键问题&#xff1a;控制长期状态信息 解决方法&#xff1a;门控开关 门的…...

Makefile学习2

自动变量和通配符 * 通配符 * 和 % 在Make 中都被称为通配符&#xff0c;但他们的含义完全不同。 * 会在你的文件系统中搜索匹配的文件名。可以在目标&#xff0c;先决条件或 wildcard 函数中使用。 print:$(wildcard *.c)ls -la $?wildcard 作用&#xff1a;在 Makefile 规…...

Axure本地化界面优化指南:全平台适配与效率提升实战

Axure本地化界面优化指南&#xff1a;全平台适配与效率提升实战 【免费下载链接】axure-cn Chinese language file for Axure RP. Axure RP 简体中文语言包&#xff0c;不定期更新。支持 Axure 9、Axure 10。 项目地址: https://gitcode.com/gh_mirrors/ax/axure-cn 作为…...

逆向尺寸:在亚马逊“越大越好”的惯性中寻找颠覆性空位

在亚马逊的每一个类目里&#xff0c;都存在着一条无形的“尺寸进化轴”——产品通常朝着功能更多、容量更大、配件更全的方向“进化”。然而&#xff0c;最犀利的破局点往往隐藏在这条主流轴线的反方向&#xff1a;一个被所有人忽视的“尺寸空位”。大众甲壳虫的“Think Small”…...

V4L2总结(1)- 编程使用总结

V4L2 编程使用总结说明&#xff1a; V4L2(Video For Linux Two) 是内核提供给应用程序访问音、视频驱动的统一接口。 流程&#xff1a; 内存映射方式打开设备文件。 int fdopen(”/dev/video0″,O_RDWR);取得设备的capability&#xff0c;看看设备具有什么功能&#xff0c…...

革新性游戏开发平台:JavaQuestPlayer一站式创意实现方案

革新性游戏开发平台&#xff1a;JavaQuestPlayer一站式创意实现方案 【免费下载链接】JavaQuestPlayer 项目地址: https://gitcode.com/gh_mirrors/ja/JavaQuestPlayer JavaQuestPlayer是一款专为游戏开发者和创作爱好者打造的革新性QSP游戏开发平台&#xff0c;通过内…...

美胸-年美-造相Z-Turbo与PID控制算法可视化教程

美胸-年美-造相Z-Turbo与PID控制算法可视化教程 1. 引言 你是不是曾经遇到过这样的情况&#xff1a;想要调整一个控制系统的参数&#xff0c;却不知道从哪里下手&#xff1f;或者看着复杂的数学公式&#xff0c;感觉头大如斗&#xff1f;今天我要介绍的这种方法&#xff0c;可…...

Qwen-Image-Edit-F2P API接口设计与RESTful规范最佳实践

Qwen-Image-Edit-F2P API接口设计与RESTful规范最佳实践 最近在帮一个朋友搭建基于Qwen-Image-Edit-F2P的图片编辑服务&#xff0c;他之前自己写了个简单的接口&#xff0c;结果上线没多久就遇到了各种问题&#xff1a;客户端调用混乱、错误信息不明确、服务器压力一大就崩。这…...

WindowsCleaner:3步解决C盘爆红难题,让你的电脑重获新生![特殊字符]

WindowsCleaner&#xff1a;3步解决C盘爆红难题&#xff0c;让你的电脑重获新生&#xff01;&#x1f680; 【免费下载链接】WindowsCleaner Windows Cleaner——专治C盘爆红及各种不服&#xff01; 项目地址: https://gitcode.com/gh_mirrors/wi/WindowsCleaner 你是否…...

开源插件全流程管理:从安装到优化的效率提升指南

开源插件全流程管理&#xff1a;从安装到优化的效率提升指南 【免费下载链接】zotero-addons Zotero add-on to list and install add-ons in Zotero 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-addons 在学术研究的数字化工作流中&#xff0c;插件管理往往成…...

电力系统动态无功补偿技术:基于MATLAB/Simulink仿真的静止无功发生器SVG与控制策...

电力系统动态无功补偿 MATLAB&#xff0c;simulink仿真 静止无功发生器SVG SVPWM控制&#xff0c;ip-iq瞬时无功电流检测&#xff0c;电压PI外环&#xff0c;电流PI内环控制。 三类负载&#xff0c;阻感性&#xff0c;阻容性&#xff0c;谐波负荷在电力系统中&#xff0c;动态无…...

嵌入式PWM蜂鸣器驱动库:轻量、确定、可移植的压电发声方案

1. 项目概述beep_sound是一个面向嵌入式微控制器的轻量级音频驱动库&#xff0c;专为通过 PWM&#xff08;脉宽调制&#xff09;信号直接驱动压电蜂鸣器&#xff08;Piezoelectric Buzzer&#xff09;而设计。其核心目标是在资源受限的 MCU 环境下&#xff0c;以极低的代码体积…...