经典算法----折半查找

二、经典算法之折半查找

很多同学对于二分法就是:一看就会,一写就废!!!!
在这里插入图片描述

易错点1:以下循环方式写哪一个?

方案一:while(left<right)
方案二:while(left<=right)

易错点2:如果arr[mid]<target,以下赋值该选哪一个(左半边同理)

方案一:right = mid;
方案二:right = mid - 1;

二、循环不变量

关于我们在while()循环当中所要搜素的数据我们将其分为以下四种

①:左闭右闭 [left,right]

在这里插入图片描述
体现在代码上就是

while(left<=right)

②:左闭右开 [left,right)

在这里插入图片描述
体现在代码上就是

while(left<right)

③:左开右闭 (left,right]

④:左开右开 (left,right)

后两种一般不做讨论,因为在实际的案例或者大型开源项目当中,所采用的的规则一般是前两种。
我们在while循环当中要坚持对区间的定义,这样才能更好的把控好易错点2当中所提出的问题,我们才能对边界做出一个理性的分析。而不是背写来…
同学们之所以会出现错误,最大原因在于没有坚持好 循环不变量这个原则,比如我们在while循环当中选择了左闭右闭,但是在操作过程当中却编程了左闭右开或者其他的什么…

三、左闭右闭 [left,right]的写法

重点解释:为什是是 right = mid -1; left=mid+1;
在这里插入图片描述
**举反例:**以下数据和目标值
在这里插入图片描述

如果我们采用的是 左闭右闭的写法,并且使用 left = mid 和 righ = mid;
第一轮:mid = 3:target<arr[mid];rigt指向mid的位置。
第二轮:mid = 0;target>arr[mid];left执行mid的位置。
第三轮:mid = 0;target>arr[mid];left执行mid的位置。
第四轮:mid = 0;target>arr[mid];left执行mid的位置。
......死循环
 public int search(int[] nums, int target) {int left = 0;int right = nums.length-1;while(left<=right){int mid = (left + right) / 2;if(nums[mid]<target){left = mid + 1;}else if(nums[mid]>target){right = mid - 1;}else if(nums[mid] == target){return mid;}else{return -1;}}   return -1;
}

四、左闭右开 [left,right)的写法

重点解释:为什是是 right = mid;和 left = mid+1;
在这里插入图片描述
举反例:
在这里插入图片描述

如果我们采用的是 左闭右开的写法,并且使用 left = mid+1 和 righ = mid - 1;
第一轮:left < right; mid = 3; target<nums[mid];:right指向了数值0的位置.....
第二轮:left < right; mid = -1; target<nums[mid];:right直接出界.....
 int left = 0;int right = nums.length; //定义右游标,这个地方要注意int mid = 0;while(left<right){mid = (left + right) / 2;if(nums[mid]<target){left = mid+1;}else if(nums[mid]>target){right = mid;}else if(nums[mid]==target){return mid;}else{return -1;}
}

总结

我们需要注意:
闭区间: 既然我们已将判断了arr[mid]<targrt或者arr[mid]>targrt,我们指针指向哪里哪里就是我们实际的索引区域,所以出现: left = mid + 1; right = mid-1;
开区间: 既然我们已将判断了arr[mid]<targrt或者arr[mid]>targrt,我们指针指向哪里哪里的下一位就是我们实际的索引区域,所以出现: left = mid; right = mid;

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

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

相关文章

【MATLAB】兔子机器人总系统_动力学模型解读(及simulink中的simscape的各模块介绍)

1、动力学模型 Rectangular Joint 控制平面上&#xff08;x&#xff0c;y轴&#xff09;的移动&#xff0c;去掉以后&#xff0c;机器人在原地翻滚不移动 Rigid Transform 坐标转换&#xff0c;B站视频已收藏 去掉&#xff0c;机体与地面贴合 此处的作用是设定机体的初…

网站建设:承诺网站打开速度,这个要求合理吗?

很多甲方都要求网站的打开速度&#xff0c;这个要求合理吗&#xff1f;其实说合理也合理&#xff0c;说不合理也不合理。 承诺打开速度的合理性的一面 要求网站打开速度是一个合理的要求。网站的打开速度对于用户体验和网站的成功至关重要。以下是一些原因说明为什么网站打开速…

2023年全国职业院校技能大赛 GZ073网络系统管理赛项 模块A:网络构建

2023年全国职业院校技能大赛 GZ073网络系统管理赛项 模块A:网络构建 卷II 一. 拓扑图 二.有线网络配置 三.无线网络配置 四.出口网络配置 二、有线配置 S1.txt S1#show running-config Building configuration... Current configuration : 5008 bytes! version RGOS 10…

[OpenWrt 22.03] ttylogin添加登录密码与禁止登录的配置

ttylogin 的使用 Openwrt 串口默认是没有密码的。Openwrt启动后,一个默认的密码将被启用去保护ssh登录和页面(http)登录,而串口登录密码却是空缺的。 对于 Openwrt,当内核初始化后,就会启动第一个进程 init,init进程会进行一系列的系统初始化工作,然后会读取 /etc/in…

微服务系列(一)springcloudAlibaba之Nacos注册和配置中心及openFeign远程调用

一&#xff0c;认识微服务 我们先看看开发大型项目采用单体架构存在哪些问题&#xff0c;而微服务架构又是如何解决这些问题的。 1.1 单体架构 单体架构&#xff08;monolithic structure&#xff09;&#xff1a;整个项目中所有功能模块都在一个工程中开发&#xff1b;项目部署…

【递归搜索回溯专栏】专题一递归:快速幂

本专栏内容为&#xff1a;递归&#xff0c;搜索与回溯算法专栏。 通过本专栏的深入学习&#xff0c;你可以了解并掌握算法。 &#x1f493;博主csdn个人主页&#xff1a;小小unicorn ⏩专栏分类&#xff1a;递归搜索回溯专栏 &#x1f69a;代码仓库&#xff1a;小小unicorn的代…

为HTTP而生的requests库,纵横江湖难逢敌手

目录 requests是什么安装requests使用requestsGET方法POST方法 requests的相关函数 既然Python是一门全球流行的语言&#xff0c;那么对于网络通信的HTTP的支持肯定也是非常的优秀的。Python中原生的urllib模块也有对HTTP的支持&#xff0c;虽然也可以用来发送 HTTP 请求&#…

Android开发新手入门教程,华为大神花费5个月打造的这份714页学习笔记系列

前言 成为一个专业人士是所有程序员的目标&#xff0c;近几年的工作经历&#xff0c;近距离观察了很多大公司的大佬。有幸与其中的一部分一起工作。在此分享大牛程序员的行为风格以及我自己的所思所想&#xff0c;希望对大家有所帮助。 特此声明&#xff1a;此为我个人主观观点…

python基础第二天

世界杯小组赛成绩 注意&#xff1a; 1.循环 1.1while 1.2for 1.3 range 1.4 while else while 循环正常执行完才能执行else语句

【Linux】磁盘情况、挂载,df -h无法看到的卷

文章目录 解决挂载、解决挂载完重启就消失1、查看linux下的硬盘挂载的空间、使用空间2、查看没有挂载的硬盘是否检测在系统中3、挂载 &#xff08;挂载完&#xff0c;要在/etc/fstab 下面配置挂载信息 要不然重启挂载就消失了&#xff09; 解决挂载、解决挂载完重启就消失 linu…

推荐一款桌面端redis连接工具, redis desktop manager替代品——another redis desktop manager

下载地址 Another Redis Desktop Manager | 更快、更好、更稳定的Redis桌面(GUI)管理客户端&#xff0c;兼容Windows、Mac、Linux&#xff0c;性能出众&#xff0c;轻松加载海量键值 封面对比 对比redis desktop manager &#xff0c;ui上有巨大的改进 但是redis desktop ma…

授权认证登录之 Cookie、Session、Token、JWT 详解

授权认证登录之 Cookie、Session、Token、JWT 详解 一、先了解几个基础概念什么是认证&#xff08;Authentication&#xff09;什么是授权&#xff08;Authorization&#xff09;什么是凭证&#xff08;Credentials&#xff09; 二、Cookie1、了解 Cookie2、cooker的创建2、coo…

嵌入式面试

1.关键字static的作用是什么&#xff1f;为什么static变量只初始化一次&#xff1f; 1&#xff09;修饰局部变量&#xff1a;使得变量变成静态变量&#xff0c;存储在静态区&#xff0c;存储在静态区的数据周期和程序相同&#xff0c; 在main函数开始前初始化&#xff0c;在退…

【刷题】双指针入门

双指针入门 双指针283.移动零1089. 复写零202. 快乐数11. 盛最多水的容器Thanks♪(&#xff65;ω&#xff65;)&#xff89;谢谢阅读&#xff01;&#xff01;&#xff01;下一篇文章见&#xff01;&#xff01;&#xff01; 双指针 双指针是非常经典的算法&#xff0c;包括但…

报错:module ‘collections‘ has no attribute ‘Iterable‘

使用python 高版本&#xff0c;在使用collections遇到报错&#xff1a;module ‘collections’ has no attribute ‘Iterable’ 查了资料 在python3.9 之后collections.Iterable被弃用了。 添加修改语句 collections.Iterable collections.abc.Iterable

保留数据的重装系统教程!(win11系统)

上车警告&#xff01;&#xff01;&#xff01; 本教程无需思考&#xff0c;跟着操作一步一步来就能完成系统的重装。原理是将C盘系统重装&#xff0c;其他盘符数据保存。适用于系统盘重装数据或更改系统版本。 重要提示&#xff01;&#xff01;&#xff01; C盘有重要学习资…

CPP编程-CPP11中的内存管理策略模型与名称空间管理探幽(时隔一年,再谈C++抽象内存模型)

CPP编程-CPP11中的内存管理策略模型与名称空间管理探幽 CPP的四大内存分区模型 在 C 中&#xff0c;**内存分区是一种模型&#xff0c;用于描述程序运行时内存的逻辑组织方式&#xff0c;但在底层操作系统中&#xff0c;并不存在严格意义上的内存分区。**操作系统通常将内存分…

太惊艳了!多微信管理利器,让你事半功倍!

作为现代社交媒体的主要平台之一&#xff0c;微信在商务领域中扮演着重要的角色。为了提高我们的工作效率&#xff0c;微信管理系统应运而生。 这个系统可以同时登录多个微信账号&#xff0c;并进行统一管理。除了便捷的登录管理功能外&#xff0c;微信管理系统还提供了许多实…

[Firefly-Linux] RK3399点亮eDP液晶屏并支持触摸

连接方法 EDP 液晶屏模组与主控的连接分为四部分: (1)屏幕背光 (2)EDP 信号 (3)电压跳线 (4)TP 触摸 屏幕背光 屏幕背光的原理图如下: BL_EN 是背光使能引脚,连接到主控的 GPIO1_A1 端口LCD_BL_PWM0 是 PWM 调光引脚,使用主控的 PWM0 端口EDP 信号 EDP 信号的…

秒杀蓝牙!华为“星闪”到底是什么?

2023年8月4日&#xff0c;华为2023HDC大会正式举办&#xff0c;鸿蒙4.0确实很惊艳&#xff0c;流畅与个性齐头并进。 但无人在意的角落&#xff0c;星闪Nearlink的星星之火即将燎原。 大会上余总对星闪一笔带过&#xff0c;众所周知&#xff0c;越不重要出现越少&#xff0c;…