【题目链接】
33. 搜索旋转排序数组
【题目描述】
在这里插入图片描述
【题解】
对于一个有序数组,我们可以使用二分查找算法来查找某个元素,具体的算法模板可以参考【算法基础课-算法模板1】基础算法中二分查找一节的内容。
然而,在这道题目中,数组并不是完全有序的,而是经过旋转后,只保证了数组的某一部分是有序的。那么,是否仍然可以使用二分查找算法呢?答案是可以的。我们可以利用旋转数组的性质,通过判断数组的哪一部分是有序的,来调整查找范围,从而有效地应用二分查找算法。
通过观察常规的二分查找算法,我们可以看到 mid 将原本有序的序列划分为 [l, mid][mid+1, r] 两个部分。因此,我们可以借鉴这一思想来解决本题。在这道题中,我们可以通过判断 [l, mid][mid+1, r] 这两部分中哪一部分是有序的,然后根据这个有序部分来调整二分查找的上下边界。具体而言,若某一部分是有序的,我们就可以判断目标值 target 是否位于该有序部分内,从而决定是将查找范围缩小到该部分,还是缩小到另一部分。这种方法使得我们能够在旋转数组中有效地找到目标值。

  • 如果[l, mid]是有序数组,且target的大小满足[nums[l], nums[mid]),则我们应该将搜索范围缩小至[l, mid - 1],否则将搜索范围缩小至[mid + 1, r]
  • 如果[mid, r]是有序数组,且target的大小满足(nums[mid], nums[r]],则我们应该将搜索范围缩小至[mid + 1, r],否则将搜索范围缩小至[l, mid - 1]

例如:
nums=[4,5,6,7,0,1,2],其中l=0,r=6,mid=3[l,mid]是有序数组,
如果target=5,在[l,mid-1]中寻找;
如果target=2,在[mid+1,r]中寻找。
nums=[6,7,0,1,2,3,4,5],其中l=0,r=6,mid=3[mid,r]是有序数组,
如果target=6,在[l,mid-1]中寻找;
如果target=4,在[mid+1,r]中寻找。

【AC代码】

class Solution {
public:int search(vector<int>& nums, int target) {int l = 0, r = nums.size() - 1;while(l <= r) {int mid = l + r >> 1;// 如果找到了目标值,直接返回下标if(nums[mid] == target)return mid;// 判断哪一部分是有序的if(nums[l] <= nums[mid]) { // 左半部分有序if(nums[l] <= target && target < nums[mid]) r = mid - 1; // 目标在左半部分,缩小右边界else //l = mid + 1; // 目标不在左半部分,缩小左边界} else { // 右半部分有序if(nums[mid] < target && target <= nums[r])l = mid + 1;  // 目标在右半部分,缩小左边界elser = mid - 1; // 目标不在右半部分,缩小右边界} }return -1;}
};

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

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

相关文章

使用 Serverless 架构快速构建基于 Iceberg 的事务型实时数据湖

文章目录1. 背景介绍2. 架构设计3. 方案实现3.1 CDC3.1.1 自定义插件3.1.2 配置 MSK Connect3.2 实时摄入3.2.1 Glue 实现方案3.2.1.1 在 Glue 中创建 Kafka connection3.2.1.2 Glue Streaming 任务3.2.2 EMS Serverless 实现方案3.3 使用 Athena 查询 Iceberg 表3.3.1 查询3.3…

Java零基础笔记20(Java高级技术:单元测试、反射、注解、动态代理)

1.单元测试2.反射2.1 反射第一步&#xff1a;加载类&#xff0c;获取类的字节码&#xff0c;class对象2.2 获取类中的成分&#xff08;构造器、成员变量、成员方法&#xff09;&#xff0c;并对其进行操作获取构造器的作用&#xff1a;获取成员变量的作用&#xff1a;获取成员…

WinDbg 调试

安装 Windows 调试器 WinDbg 是一种调试器,可用于分析故障转储、调试实时用户模式和内核模式代码,以及检查 CPU 寄存器和内存。 此最新版本具有更新的界面、完全现成的脚本功能、可扩展的调试数据模型、内置的时间旅行调试(TTD)支持和许多其他功能,具有更现代的用户体验。…

topographic terrain

在中文语境中&#xff0c;topographic&#xff08;地形学&#xff09;和 terrain&#xff08;地形&#xff09;这两个词都与地表特征相关&#xff0c;但它们的含义和使用场景有细微差别。以下是它们的区别&#xff1a; 1. 定义Topographic&#xff08;地形学的&#xff09;&…

SpringCloud 06 服务容错 Sentinel

雪崩&#xff1a;一个微小的故障引起系统其他部分出现故障&#xff0c;最终使整个系统不可用。 雪崩一般经历以下三个阶段&#xff1a; 实例能力出现过载。可能是 bug 导致性能下降&#xff0c;可能是实例宕机&#xff0c;可能是突发流量&#xff0c;总之实例无法处理如此多请求…

Qt同步处理业务并禁用按钮

1.界面代码 //按钮1 void Dialog::on_pushButton1_clicked() {qDebug("pushButton1 clicked start");enableBtns(false);//禁用按钮qDebug("pushButton1 do sth start");QThread::sleep(5);//休眠&#xff0c;作为同步处理业务qDebug("pushButton1 do…

虚拟专用网技术

一、需求背景物理联通&#xff1a;实现不同物理位置网络的连接基础。网络联通&#xff1a;在物理连接基础上&#xff0c;实现数据等信息的传输互通。二、虚拟专用网简介定义虚拟私有网络是依靠互联网服务提供商&#xff08;ISP&#xff09;或其他网络服务提供商&#xff08;NSP…

GANs生成对抗网络生成手写数字的Pytorch实现

目录 一、第三方库导入 二、数据集准备 三、使用转置卷积的生成器 四、使用卷积的判别器 五、生成器生成图像 六、主程序 七、运行结果 7.1 生成器和判别器的损失函数图像 7.2 训练过程中生成器生成的图像 八、完整的pytorch代码 由于之前写gans的代码时&#xff0c;…

ubuntu 通过NAT模式上网

这里必须使用VMnet8 设置为NAT模式 下面设置Ip地址区域ubuntu ip地址设置来自于上面

盲盒抽谷机小程序系统开发:从0到1的完整方法论

开发一款成功的盲盒抽谷机小程序系统&#xff0c;需兼顾技术实现、用户体验与商业逻辑。本文将从需求分析、UI/UX设计、技术架构、测试上线到运营增长&#xff0c;系统梳理从0到1的完整方法论。需求分析&#xff1a;明确“为谁而做”盲盒抽谷机的核心用户是18-35岁的二次元爱好…

web开发,在线%射击比赛管理%系统开发demo,基于html,css,jquery,python,django,三层mysql数据库

经验心得 两业务单&#xff0c;业务crud开发很简单了&#xff0c;自行学习&#xff0c;我说一下学习流程。什么是前端&#xff0c;用到那些技术html,css,javascript分别是什么&#xff1f;进阶jquery,bootstrap,各种常见前端组件又是什么&#xff0c;前端框架react,angular以及…

Centos9傻瓜式linux部署CRMEB 开源商城系统(PHP)

服务器环境推荐要求* Nignx&#xff08;必须&#xff09; * PHP 7.1 ~ 7.4&#xff08;必须此版本内&#xff0c;版本过大会警告不兼容&#xff09; * MySQL 5.7 &#xff5e; 8.0&#xff08;必须&#xff09; * Redis&#xff08;非必须&#xff09;后台页面展示&#xff1a;…

AI 云电竞游戏盒子:从“盒子”到“云-端-芯”一体化竞技平台的架构实践

摘要 AI 云电竞游戏盒子&#xff08;以下简称“电竞盒”&#xff09;不再是一台简单的客厅游戏主机&#xff0c;而是一套以 AI 调度为核心、以云原生架构为骨架、以边缘渲染为肌肉、以端侧感知为神经的“云-端-芯”协同竞技系统。本文基于 2024 年 Q2 落地的量产方案&#xff0…

基于kuboard实现kubernetes的集群管理

1、前提条件安装docker-compose2、步骤在本地目录创建kuboard-v4\在该目录下创建文件docker-compose.yaml&#xff0c;内容如下&#xff1a;configs:create_db_sql:content: |CREATE DATABASE kuboard DEFAULT CHARACTER SET utf8mb4 DEFAULT COLLATE utf8mb4_unicode_ci;cre…

Linux操作系统软件编程——多线程

什么是线程线程的定义是轻量级的进程&#xff0c;可以实现多任务的并发。线程是操作系统任务调度的最小单位线程的创建由某个进程创建&#xff0c;且进程创建线程时&#xff0c;会为其分配独立的栈区空间&#xff08;默认8M&#xff09;。线程和所在的进程&#xff0c;以及进程…

linux下找到指定目录下最新日期log文件

以下是一个完整的C函数&#xff0c;用于在指定目录下自动查找最近更新的日志文件&#xff08;根据文件名中的时间戳选择最新的文件&#xff09;&#xff1a;#include <stdio.h> #include <stdlib.h> #include <string.h> #include <dirent.h> #include…

《数学模型》经典案例——钢管的订购与运输

一、问题描述 要铺设一条 A1→A2→⋯→A15A_1 \rightarrow A_2 \rightarrow \cdots \rightarrow A_{15}A1​→A2​→⋯→A15​ 的输送天然气的主管道&#xff0c;如图 6.22 所示。经筛选后可以生产这种主管道钢管的钢厂有 S1,S2,⋯,S7S_1, S_2, \cdots, S_7S1​,S2​,⋯,S7​ 。…

Java Web部署

今天小编来分享下如何将本地写的Java Web程序部署到Linux上。 小编介绍两种方式&#xff1a; 部署基于Linux Systemd服务、基于Docker容器化部署 首先部署基于Linux Systemd服务 那么部署之前&#xff0c;要对下载所需的环境 软件下载 Linux&#xff08;以ubuntu&#xf…

告别AI“炼丹术”:“策略悬崖”理论如何为大模型对齐指明科学路径

摘要&#xff1a;当前&#xff0c;我们训练大模型的方式&#xff0c;尤其是RLHF&#xff0c;充满了不确定性&#xff0c;时常产生“谄媚”、“欺骗”等怪异行为&#xff0c;被戏称为“炼丹”。一篇来自上海AI Lab的重磅论文提出的“策略悬崖”理论&#xff0c;首次为这个混沌的…

深入理解C#特性:从应用到自定义

——解锁元数据标记的高级玩法&#x1f4a1; 核心认知&#xff1a;特性本质揭秘 public sealed class ReviewCommentAttribute : System.Attribute { ... }特性即特殊类&#xff1a;所有自定义特性必须继承 System.Attribute&#xff08;基础规则&#xff09;命名规范&#xff…