33. 搜索旋转排序数组 --力扣 --JAVA

题目

整数数组 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 。

你必须设计一个时间复杂度为 O(log n) 的算法解决此问题。

解题思路

  1. 数组有序且时间复杂度为O(log n) ,可以联想到二分查找;
  2. 二分查找就是寻找中间值将数组不断拆分进行判断;
  3. 数组一部分旋转,所以在进行二分查找的时候需要判断中间值所在的位置是否旋转;
  4. 判断目标值可能处于左右那一部分;
  5. 不断拆分,直到临界点,即:区间左边界>=右边界;
  6. 判断右边界是否越界,是否等目标值。

代码展示

class Solution {public int search(int[] nums, int target) {int n = nums.length;if(n == 0) return -1;if(n == 1) return nums[0] == target ? 0 : -1;int left = 0;int right = n - 1;int mid = 0;while (left < right) {mid = (left + right) / 2;if(nums[mid] == target) return mid;if(nums[mid] >= nums[left]){         //证明中间节点未被旋转if(target < nums[mid] && target >= nums[left]){right = mid - 1;} else {left = mid + 1;}} else{                             //证明中间节点被旋转if(target > nums[mid] && target <= nums[right]){left = mid + 1;} else {right = mid - 1;}}}if(right < 0) return - 1;return target == nums[right] ? right : -1;}
}

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

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

相关文章

WPS的JS宏如何实现全文件路径字符串中截取文件名(excel)

从全文件路径的字符串中&#xff0c;截取文件名称&#xff0c;例如&#xff1a; 全文件路径字符串为&#xff1a;C:\Windows\System32\drivers\acpi1.sys 需要截取文件名&#xff1a;acpi1.sys 方法如下&#xff1a; 1、简单的方式&#xff1a;把全文件路径字符串拷贝&…

面试:sleep 和 wait

一、共同点 wait(),wait(long)和sleep(long)的效果都是让当前线程暂时放弃CPU的使用权&#xff0c;进入阻塞状态 二、不同点 1、方法归属不同 sleep(long)是Thread的静态方法而wait(), wait(long)都是Object的成员方法&#xff0c;每个对象都有 2、醒来的时机不同 执行sleep(l…

._locked勒索病毒的最新威胁:如何恢复您的数据?

导言&#xff1a; 近年来&#xff0c;网络安全问题日益凸显&#xff0c;各种勒索病毒层出不穷&#xff0c;其中._locked勒索病毒以其独特的攻击方式和广泛的传播范围引起了广泛关注。本文91数据恢复将介绍._locked勒索病毒的特点&#xff0c;并探讨有效的应对策略&#xff0c;…

汉语言文学毕业论文《谈陶渊明田园风光诗的艺术特色》7000字

答案&#xff1a;更多答案&#xff0c;请关注【电大搜题】微信公众号 答案&#xff1a;更多答案&#xff0c;请关注【电大搜题】微信公众号 答案&#xff1a;更多答案&#xff0c;请关注【电大搜题】微信公众号 论文 中文题目&#xff1a;谈陶渊明田园风光诗的艺术特色 …

NTC热敏电阻采集温度-单片机通用模板

NTC热敏电阻采集温度-单片机通用模板 一、NTC热敏电阻转换温度的原理二、AT104Tem.c的实现三、AT104Tem.h的实现 一、NTC热敏电阻转换温度的原理 ①NTC热敏电阻会随着温度的升高&#xff0c;电阻值R逐渐降低&#xff1b;②硬件搭建电阻分压电路采集ADC逆推热敏电阻当前的阻值&…

JavaScript中的Promise、Async和Await

Promise 基础 Promise是JavaScript中用于处理异步操作的一个关键概念。它代表了一个尚未完成但预期在将来完成的操作。使用Promise&#xff0c;可以避免所谓的“回调地狱”&#xff0c;即多层嵌套的回调函数&#xff0c;从而使代码更加清晰和易于维护。 代码示例&#xff1a;…

C语言学习笔记之指针(二)

指针基础知识&#xff1a;C语言学习笔记之指针&#xff08;一&#xff09;-CSDN博客 目录 字符指针 代码分析 指针数组 数组指针 函数指针 代码分析&#xff08;出自《C陷阱和缺陷》&#xff09; 函数指针数组 指向函数指针数组的指针 回调函数 qsort() 字符指针 一…

新版AndroidStudio使用switch-case语句时出现Constant expression required错误

原因: 在新版的Android Studio中使用JDK17以上版本&#xff0c;会出现switch语句报错"Constant expression required"的问题&#xff0c;这是因为在JDK17中switch语句的条件表达式支持使用枚举类型&#xff0c;而这个特性还没有被支持。 解决方法: ①在gradle.prope…

UE4_动画基础_不同骨骼的动画重定向步骤

学习笔记&#xff0c;仅供参考&#xff01; 1、导入fbx外部资源&#xff0c;不包含动画&#xff0c;需要使用小白人动画资源。 2、打开Girl_Skeleton。发现骨骼数量不同&#xff0c;要想使用另一个骨骼的动画资源&#xff0c;需要进行不同骨骼的动画重定向。 3、打开小白人骨骼…

Redis 使用小记

Redis提供了五种主要的数据结构&#xff0c;每种都有其特定的用途和一系列操作。以下是每种数据结构及其常见操作的概述&#xff1a; String&#xff08;字符串&#xff09;: 基本操作: SET, GET, DEL 等。用于存储文本或二进制数据。支持的操作包括设置、获取、删除字符串值&a…

再谈癌症基础与转化研究中的大数据科学

再谈癌症基础与转化研究中的大数据科学 李升伟1 茅 矛1 陈 竺2 &#xff08;1.特趣生物科技有限公司&#xff0c;广东省深圳市&#xff1b;2.上海交通大学医学院附属 瑞金医院&#xff0c;上海市&#xff09; 癌症基础与转化研究中的大数据科学涵盖了从数据采集、整合、…

作为研究生应该怎么阅读文献

作为研究生&#xff0c;阅读文献是一个至关重要的学术活动&#xff0c;帮助你建立专业知识基础&#xff0c;了解领域内的最新研究进展&#xff0c;并为自己的研究找到合适的定位。下面是一些有效的文献阅读策略&#xff1a; 1. 确定阅读目标 初步了解&#xff1a;快速浏览文献…

Avalonia中嵌入网页程序(CefNet)运行在银河麒麟系统上

目录 操作系统版本项目目录结构引入Nuget包扩展一个CefNetApplication类改造App.cs文件启动类改造以及cef全局目录设置主窗口代码实现下载 cef 基础环境将cef基础环境放入Program代码里面设置的全局目录下打银河麒麟下的安装包复制安装包去银河麒麟系统上安装并看效果(完美)本文…

007 springboot整合mybatis-plus 增删改查 ajax(修改部分是) jquery 分页

文章目录 MybatisplusConfig.javaReceiveAddressJsonController.javaReceiveAddress.javaReceiveAddressMapper.javaIReceiveAddressService.javaReceiveAddressServiceImpl.javaServerResult.javaServletInitializer.javaSpringbootDemoApplication.javareceive_address.sqlRe…

国密SM2+RSA+AES+MD5加解密,验签流程,工具示例,增强版完善版(包含前后端加解密验签流程)

详见资源包 https://download.csdn.net/download/x948130516/89119461?spm1001.2014.3001.5503 前端引入依赖 使用hutool工具进行签名和验签时&#xff0c;前端需要传入第三个json对象参数&#xff0c;否则会验签失败 前端使用npm install --save sm-crypto引入依赖库 前…

ORACLE数据库版本与表名、字段名、视图名、序列名和主键最大长度的关系

在Oracle 12.1版本及之前&#xff08;如Oracle 11g&#xff09;&#xff0c;建表表名的最大长度是30个字符。这个长度限制适用于所有标识符&#xff0c;包括表名、字段名、视图名、序列名和主键等。 如果尝试创建包含超过30个字符的表名&#xff0c;系统会报ORA-00972错误&…

mmap函数小实验

mmap函数小实验 文章目的参数 length 不是页大小的整数倍会怎样&#xff1f;研究过程length结论 参数 offset 取不同的值时会怎样&#xff1f;研究过程offset 结论 参考链接 文章目的 本文是为了深入理解mmap的参数length与offset对mmap函数行为的影响&#xff0c;从而更好地理…

反转链表【java】

给定一个链表的头节点head反转链表 方法一&#xff1a;循环 1.定义三个指针&#xff1a; pre指针&#xff1a;刚开始指向空 prenull cur指针&#xff1a;刚开始指向head节点 curhead temp指针&#xff1a;保存cur指针指向节点的下一个节点 2. 不断循环改变相邻两个节点的指…

Spring MVC 中的统一异常处理

文章目录 Spring MVC 中的统一异常处理Spring MVC 中跳转自定义 404 页面的两种常见方式在 web.xml 中指定自定义的 404 页面提供一个匹配 * 的 Controller 请求处理方法 使用 ExceptionHandler 注解使用 ControllerAdvice ExceptionHandler 注解使用示例控制生效的 Controlle…

JavaWeb前端/后端开发规范——接口文档概述及YApi平台的使用

前言&#xff1a; 整理下笔记&#xff0c;打好基础&#xff0c;daydayup!!! 接口文档 什么是接口文档&#xff1f; 目前主流的开发模式为前后端分离式开发&#xff0c;为了方便前后端的对接&#xff0c;就需要使用接口文件进行统一规范。 接口文档记载什么信息&#xff1f; 1&…