33. 搜索旋转排序数组(013)二分查找+思路详解+来干了这杯代码!!!!!!

一:题目

整数数组 nums 按升序排列,数组中的值 互不相同 。

在传递给函数之前,nums 在预先未知的某个下标 k(0 <= k < nums.length)上进行了 旋转,使数组变为 [nums[k], nums[k+1], …, nums[n-1], nums[0], nums[1], …, nums[k-1]](下标 从 0 开始 计数)。例如, [0,1,2,4,5,6,7] 在下标 3 处经旋转后可能变为 [4,5,6,7,0,1,2] 。

给你 旋转后 的数组 nums 和一个整数 target ,如果 nums 中存在这个目标值 target ,则返回它的下标,否则返回 -1 。

示例 1:

输入:nums = [4,5,6,7,0,1,2], target = 0
输出:4
示例 2:

输入:nums = [4,5,6,7,0,1,2], target = 3
输出:-1
示例 3:

输入:nums = [1], target = 0
输出:-1

二:思路

思路: 1.因为题目说了这是一个升序的数组,然后变成了旋转数组,那么就可以用二分法
2.那么关于使用二分法:这里分了两步
(1):利用nums[mid] 和 nums[0],来进行判断所分出的两部分中那一部分为有序的
如果nums[mid] > nums[0]的话,那么mid左边的序列为有序的
如果nums[mid] < nums[0]的话,那么mid右边为有序序列
(2):判断出有序序列后,接下来就是判断target是否在该序列中,
如果在左边有序的序列中 nums[l] <= target && target < nums[mid]
这时右边界条件就得进行变化,r = mid - 1;
否则 那么 target 就在 左边的无序列表当中,那么的话我们就又要判断那部分是和 无序的,和 nums[mid]进行比较。。。 和上方一致,
如果在右边的有序序列中 nums[mid] <= target && target < nums[r]
这时左边界:l = mid + 1;
否则类似上方

(3):注意(target和num[l])和(target和num[r]) 因为每次判断有序的范围是跟已
经判断target在哪个区间以内了,所以需要更新比较的边界值

三:上码

	class Solution {
public:int search(vector<int>& nums, int target) {/**思路: 1.因为题目说了这是一个升序的数组,然后变成了旋转数组,那么就可以用二分法2.那么关于使用二分法:这里分了两步(1):利用nums[mid] 和 nums[0],来进行判断所分出的两部分中那一部分为有序的如果nums[mid] > nums[0]的话,那么mid左边的序列为有序的如果nums[mid] < nums[0]的话,那么mid右边为有序序列(2):判断出有序序列后,接下来就是判断target是否在该序列中,如果在左边有序的序列中 nums[l] <= target && target < nums[mid]这时右边界条件就得进行变化,r = mid - 1;否则 那么 target 就在 左边的无序列表当中,那么的话我们就又要判断那部分是和                  无序的,和 nums[mid]进行比较。。。。和上方一致,如果在右边的有序序列中 nums[mid] <= target && target < nums[r]这时左边界:l = mid + 1;否则类似上方  (3):注意(target和num[l])和(target和num[r])  因为每次判断有序的范围是跟已        经判断target在哪个区间以内了,所以需要更新比较的边界值          */int n = nums.size();if(n == 0){return -1;}if(nums[0] == target){return 0;}int l = 0;int r = n - 1;int mid;while(l <= r){mid = (l + r)/2;if(nums[mid] == target){return mid;}if(nums[mid] >= nums[l]){//左边序列是有序的if(target >= nums[l] && target < nums[mid]){r = mid - 1;}else{l = mid + 1; }}else{//右边是有序的if(target > nums[mid] && target <= nums[r]){//target在右边的序列中l = mid + 1;}else{r = mid - 1;}}}return -1;}
};

在这里插入图片描述
加油 BOY!!!and girl

特别提醒 :要特别注意本题的边界条件

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

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

相关文章

计算机软件在矿井地质中的应用,(完整版)遥感导论知识点整理(梅安新版)

遥感导论知识点整理【题型】一、选择题二、填空题三、名词解释四、简答题五、论述题注意&#xff1a;标注页码的地方比较难理解&#xff0c;希望大家多看看书&#xff0c;看看ppt。【第一章】绪论1、【名】遥感(remote sensing)广义&#xff1a;泛指一切无接触的远距离探测&…

81. 搜索旋转排序数组 II(014)二分查找+思路+详解+二种做法

一&#xff1a;题目 已知存在一个按非降序排列的整数数组 nums &#xff0c;数组中的值不必互不相同。 在传递给函数之前&#xff0c;nums 在预先未知的某个下标 k&#xff08;0 < k < nums.length&#xff09;上进行了 旋转 &#xff0c;使数组变为 [nums[k], nums[k1…

学校考的计算机三级证书,全国计算机等级考试证书用途

全国计算机等级考试证书用途计算机知识浩如瀚海&#xff0c;即使任何资深人士都不可能精通或熟悉所有的计算机软件&#xff0c;但是为什么他们无论什么软件都能很快就上手会用呢&#xff0c;那是因为本质上任何计算机软件都是C语言之类的编程语言开发出来的&#xff0c;所以我们…

如何校验内存数据的一致性,DynamicExpresso 算是帮上大忙了

一&#xff1a;背景1. 讲故事记的在上一家公司做全内存项目的时候&#xff0c;因为一些关键表会在程序 startup 的时候全量灌入到内存中&#xff0c;但随着时间的推移&#xff0c;内存和数据库的同步偶尔会出现数据差异的情况&#xff0c;伴随着就是运营那边报过来的 bug&#…

临界表储存图的数据(思路+详解+图示)

一&#xff1a;前言 当我们考虑用邻接表储存数据的时候&#xff0c;一定会拿邻接矩阵和其进行比较。邻接矩阵在储存数量较小的数据是耗费的内存是要高于邻接表的。那么我们在做题的时候如果出现内存超限&#xff0c;那就要注意了&#xff0c;可以考虑换用邻接表来储存数据了 …

译 | 在 Azure SQL 上节约成本的八种方法

点击上方关注“汪宇杰博客”原文&#xff1a;John JG Chirapurath翻译&#xff1a;汪宇杰导语当今世界&#xff0c;企业正崭露头角&#xff0c;渴望重整与重建&#xff0c;但仍处于不确定的时期。节约成本并将开支重新分配到最重要的位置与以往一样重要&#xff0c;许多公司将云…

7-2 单源最短路径 (10 分)(思路+详解+邻接表做法)Come Brather!!!!!!!!!!

一&#xff1a;前言 本次题解先展示用邻接矩阵做的&#xff0c;但其会出现内存超限&#xff0c;因为确实是临界矩阵在数据很大的时候相比临界表是耗内存的&#xff0c;但是以前习惯用临界矩阵了&#xff0c;所以一上来就用临界矩阵做了&#xff0c;后来上网查了后知道邻接矩阵…

在.NET Core中使用MongoDB明细教程(3):Skip, Sort, Limit, Projections

到目前为止&#xff0c;我们已经讨论了创建文档, 检索文档&#xff0c;现在让我们来研究一下文档排序&#xff0c;指定要跳过或限制返回的文档数量&#xff0c;以及如何进行投影。此篇文章中的实例代码摘录自原文&#xff0c;未像前几篇文章一样进行实际代码的验证。作者&#…

map容器的使用 逆序遍历map容器当中的数据

一&#xff1a;前言 这个逆序遍历是将map容器的迭代器进行了变化&#xff0c;reverse_iterator逆向遍历的迭代器 &#xff0c;它需要 rbegin()和rend()方法指出反向遍历的 起始位置和终止位置。 二&#xff1a;上码演示 #include<bits/stdc.h> using namespace std;in…

递归优化的这三种方式你知道吗?

估计找工作的&#xff0c;都会碰到面试官老是问道“递归算法”&#xff0c;感同身受&#xff0c;前段时间面试的时候&#xff0c;就有一家问道这个问题&#xff0c;是非常典型的问题。在前面一篇世界上有哪些代码量很少&#xff0c;但很牛逼很经典的算法或项目案例&#xff1f;…

7-7 硬币找钱问题 (10 分)(思路+详解+double类型数据的处理)Come baby!!!!!!!!!!!!!!!!!!!!

一&#xff1a;题目 设有6 种不同面值的硬币&#xff0c;各硬币的面值分别为5 分&#xff0c;1 角&#xff0c;2 角&#xff0c;5 角&#xff0c;1 元&#xff0c;2元。现要用这些面值的硬币来购物。在购物中希望使用最少个数硬币。例如&#xff0c;1 次购物需要付款0.55 元&a…

7-6 区间覆盖 (10 分)(思路+详解)Come 宝!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

一&#xff1a;题目 设 x 1 ​ ,x 2 ​ ,…,x n ​ 是实直线上的n个点。用固定长度的闭区间覆盖这n个点&#xff0c;至少需要多少个这样的固定长度闭区间&#xff1f; 输入格式: 第1行有2个正整数n(n<50)和k&#xff0c;表示有n个点&#xff0c;且固定长度闭区间的长度为k…

你有 GitHub 帐号么?平时都用它来干什么?

这是头哥侃码的第212篇原创上个月&#xff0c;我写了一篇 #与抑郁症斗争的那些年&#xff0c;我也曾想去死一死#&#xff0c;分享了自己在创业失败那段时间的抑郁焦虑的经历。很显然&#xff0c;这已经不是我第一次把自己的悲惨经历写出来了。在文章推送后&#xff0c;有读者在…

7-5 汽车加油问题 (20 分)(思路+详解)Come 宝!!!!!!!!!!!!!

一&#xff1a;题目 题目来源&#xff1a;王晓东《算法设计与分析》 一辆汽车加满油后可行驶 n公里。旅途中有若干个加油站。设计一个有效算法&#xff0c;指出应 在哪些加油站停靠加油&#xff0c;使沿途加油次数最少。 输入格式: 第一行有 2 个正整数n和 k&#xff08;k&l…

在生产环境下处理EFCore数据库迁移的五种方法

在生产环境下处理EFCore数据库迁移的五种方法原文链接&#xff1a;https://www.thereformedprogrammer.net/handling-entity-framework-core-database-migrations-in-production-part-1/作者:Jon P Smith&#xff0c;是《 Entity Framework Core in Action》的作者安德鲁洛克&a…

计算机系统结构答案汤志忠,计算机系统结构(第2版)郑伟明汤志忠课后习题答案以及例题收录.doc...

计算机系统结构(第2版)郑伟明汤志忠课后习题答案以及例题收录.doc 1计算机系统结构第2版郑伟明汤志忠编著清华大学出版社习题解答21目录11第一章P331719(透明性概念)&#xff0c;112118(AMDAHL定律)&#xff0c;119、121、124(CPI/MIPS)12第二章P12423、25、26(浮点数性能)&…

7-1 活动选择问题 (25 分)(思路+详解+扩展)宝 今天你AC了吗!!!

一&#xff1a;题目 假定一个有n个活动(activity)的集合S{a 1 ​ ,a 2 ​ ,…,a n ​ }&#xff0c;这些活动使用同一个资源&#xff08;例如同一个阶梯教室&#xff09;&#xff0c;而这个资源在某个时刻只能供一个活动使用。每个活动a i ​ 都有一个开始时间s i ​ 和一个结…

初识ABP vNext(5):ABP扩展实体

点击上方蓝字"小黑在哪里"关注我吧扩展实体路由整理前言上一篇实现了前端vue部分的用户登录和菜单权限控制&#xff0c;但是有一些问题需要解决&#xff0c;比如用户头像、用户介绍字段目前还没有&#xff0c;下面就来完善一下。开始因为用户实体是ABP模板自动生成的…

7-8 最优服务次序问题 (10 分)

一 &#xff1a;题目 设有n 个顾客同时等待一项服务。顾客i需要的服务时间为 t i ​ (1<i<n) 。应如何安排n个顾客的服务次序才能使平均等待时间达到最小&#xff1f;平均等待时间是n 个顾客等待服务时间的总和除以n。 输入格式: 第一行是正整数n(1<n<1000)&…

.NET Core + K8S + Apollo 玩转配置中心

1.引言Apollo&#xff08;阿波罗&#xff09;是携程框架部门研发的分布式配置中心&#xff0c;能够集中化管理应用不同环境、不同集群的配置&#xff0c;配置修改后能够实时推送到应用端&#xff0c;并且具备规范的权限、流程治理等特性&#xff0c;适用于微服务配置管理场景。…