Java [leetcode 33]Search in Rotated Sorted Array
2024-10-16 01:49:41
题目描述:
Suppose a sorted array is rotated at some pivot unknown to you beforehand.
(i.e., 0 1 2 4 5 6 7
might become 4 5 6 7 0 1 2
).
You are given a target value to search. If found in the array return its index, otherwise return -1.
You may assume no duplicate exists in the array.
解题思路:
采用二分查找法查找,若最后没有找到返回-1,否则过程中返回具体的位置。
代码如下:
public class Solution {
public int search(int[] nums, int target) {
int left = 0;
int right = nums.length - 1;
while (left <= right) {
int mid = (left + right) / 2; if (nums[mid] == target)
return mid;
if (nums[left] == target)
return left;
if (nums[right] == target)
return right; 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;
}
}
return -1;
}
}
最新文章
- MyBatis3:SQL映射
- 使用hexo搭建github.io博客(一)
- 实用SQL语句大全
- NOI2018准备Day13晚
- XAF学习笔记1
- ngx.lua中遇到的小问题
- Linux_查看进程
- Object Pascal 语法之异常处理
- HMM TOOL
- 【英语】Bingo口语笔记(10) - 常见词汇的缩读
- HttpClient(联网)
- Visual Studio Code开发TypeScript
- c语言 内存管理
- java之Spring实现控制反转
- Vue学习记录第二天
- spark-streaming集成Kafka处理实时数据
- js map()与forEach()的用法与区别
- 【警告】WARN: Establishing SSL connection without server&#39;s identity verification is not recommended.
- OpenJudge NOI 4976 硬币
- CentOS 网卡自动启动、配置等ifcfg-eth0教程