leetcode 33. 搜索旋转排序数组

news/2025/2/12 19:36:30/

2023.9.26

        本题暴力法可以直接A,但是题目要求用log n的解法。 可以想到二分法,但是一般二分法适用于有序数组的,这里的数组只是部分有序,还能用二分法吗? 答案是可以的。因为数组是经过有序数组旋转得来的,所以在二分之后,左右两边必有一边是有序的。  具体细节看代码:

class Solution {
public:int search(vector<int>& nums, int target) {int left = 0;int right = nums.size()-1;while(left <= right){int mid = (left + right) / 2;if(nums[mid] == target) return mid;//左半边升序的情况if(nums[0] <= nums[mid]){if(target < nums[mid] && target >= nums[0]){right = mid - 1;}else left = mid + 1;}//右半边升序的情况else{if(target > nums[mid] && target <= nums[nums.size()-1]){left = mid + 1;}else right = mid - 1;}}return -1;}
};

 


http://www.ppmy.cn/news/1125937.html

相关文章

计算机网络补充

未分类文档 CDMA是码分多路复用技术 和CMSA不是一个东西 UPD是只确保发送 但是接收端收到之后(使用检验和校验 除了检验的部分相加 对比检验和是否相等。如果不相同就丢弃。 复用和分用是发生在上层和下层的问题。通过比如时分多路复用 频分多路复用等。TCP IP 应用层的IO多路…

AnolisOS8安装Docker

AnolisOS8安装Docker 一、环境二、安装2.1 环境配置2.2 安装docker 一、环境 系统&#xff1a;Anolis OS 8.6 docker版本&#xff1a;lastest docker-compose版本&#xff1a;lastest 二、安装 2.1 环境配置 # 更新镜像源 dnf makecache # 查看时间服务器状态 chronyc source…

flv怎么转换成mp4格式?准备3个方法给大家

flv怎么转换成mp4格式&#xff1f;FLV是一种流行的视频文件格式&#xff0c;最初由Adobe公司开发&#xff0c;用于在Web上播放和传输视频内容。FLV格式以其较小的文件大小和较高的压缩比而闻名&#xff0c;并广泛应用于在线视频分享平台、流媒体服务和网络广告等领域。能够提供…

esbuild中文文档-语法转换(Transformation - Supported、Target)

文章目录 语法转换 Transformation配置支持的语法 Supported构建目标 Target 结语 哈喽&#xff0c;大家好&#xff01;我是「励志前端小黑哥」&#xff0c;我带着最新发布的文章又来了&#xff01; 老规矩&#xff0c;小手动起来~点赞关注不迷路&#xff01; esbuild简单介绍 …

香橙派OrangePi的风扇怎么接

跟树莓派类似&#xff0c;看主板上GPIO口的阵脚定义 树莓派的引脚定义官网&#xff1a;Raspberry Pi Documentation - Raspberry Pi hardware 树莓派的4口和6口可以接一个5V小风扇&#xff0c;4口接正极&#xff0c;6口接负极即可&#xff0c;由于接口相近&#xff0c;可以用于…

RK3588平台开发系列讲解(项目篇)视频监控之RTMP推流

文章目录 一、RTMP协议是什么二、RTMP 的原理三、Nginx 流媒体服务器四、FFmpeg 推流沉淀、分享、成长,让自己和他人都能有所收获!😄 📢 目前常见的视频监控和视频直播都是使用了 RTMP、RTSP、HLS、MPEG-DASH、WebRTC流媒体传输协议等。 视频监控项目组成,分为三部分:…

深入学习计算机组成原理文章体系

大家好&#xff0c;欢迎阅读《计算机组成原理》的系列文章&#xff0c;本系列文章主要教内容是从零学习计算机组成原理&#xff0c;内容通俗易懂&#xff0c;大家好好学习吧&#xff01;&#xff01;&#xff01; 更多的优质内容&#xff0c;请点击以下链接查看哦~~ 序号链接…

十年前对敏捷开发的体会

说明 翻到10年前的旧文&#xff0c;发出来。记录自己的成长。 正文 敏捷开发强调灵活性&#xff0c;适合小而精的团队。许多小公司10年来一直稳定在五个程序员&#xff0c;可能适用。 四大价值观 个体与交互甚于流程与工具。非常适合小而精的团队。沟通的成本正比于人员的平…