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

leetcode 33. Search in Rotated Sorted Array

题目描述

可以发现的是,将数组从中间分开成左右两部分的时候,一定至少有一部分的数组是有序的。左部分[left,mid-1],右部分[mid+1,right]。

第一种情况:左右两部分都是有序的,说明nums[mid]就是整个数组的最大值。此时只需要判断target在哪个部分,然后去那个部分做正常的二分查找即可。

第二种情况,左右两部分只有一部分是有序的。此时看target是否在有序的那部分。如果是,那就去有序的那部分做正常的二分查找。如果否,说明target在无序的部分,并且问题规模缩小一半,重复前面的逻辑即可。

class Solution {
public:int search(vector<int>& nums, int target) {int left = 0;int right = nums.size() -1;int mid = 0;while(left<=right){mid = left + ((right-left)>>1);if(nums[mid] == target)return mid;if(left <= mid-1 && nums[left] <= nums[mid-1])//左半部分有序{if(nums[left]<=target&&target<=nums[mid-1])//target在左半部分之中right = mid-1;elseleft = mid +1;}else//右半部分有序{if(mid+1<=right && nums[mid+1]<=target&&target<=nums[right])//target在右边部分之中left = mid+1;elseright = mid -1;}}return -1; }
};
http://www.xdnf.cn/news/558217.html

相关文章:

  • vue图片懒加载指令实现
  • 指针深入理解(二)
  • 在表格中使用AI解析通信协议
  • Vue3 父子组件传值, 跨组件传值,传函数
  • 进程——概念及状态
  • 算法训练之分治(快速排序)
  • 浏览器播放 WebRTC 视频流
  • 从客厅到驾驶舱:FSHD 如何成为全场景显示「破局者」
  • 第四十一节:人脸检测与识别-Haar 级联分类器
  • 城市共治的伦理平台愿景
  • 第6天-Python操控摄像头:从入门到实战
  • 四元数中 w xyz 的含义及应用
  • 通义灵码助力JavaScript开发:快速获取API与智能编码技巧
  • celery独立部署接入数据库配置
  • 【C++算法】68.栈_字符串解码
  • 关于Linux服务器数字取证一
  • pytorch小记(二十四):PyTorch 中的 `torch.full` 全面指南
  • Python 包管理工具 uv
  • RocketMQ 的事务消息是如何实现的
  • 【Java高阶面经:微服务篇】3.熔断机制深度优化:从抖动治理到微服务高可用架构实战
  • unipp === 状态管理 Pinia 使用
  • 萌新联赛第(三)场
  • 自建主机NAS
  • Java转Go日记(四十二):错误处理
  • 链表-设计链表
  • OBS Studio:windows免费开源的直播与录屏软件
  • Tractor S--二维转一维,然后最小生成树
  • Python 中 pass 语句的详解和使用
  • Java双指针法:原地移除数组元素
  • IEEE出版|2025年智能光子学与应用技术国际学术会议(IPAT2025)