leetcode 33. 搜索旋转排序数组

一、题目

image

二、解法

本题是二分法的变种。和标准二分问题的不同在于,二分后,两个区间不都是有序的,但必有一个有序,另一个可能有序也可能无序。

class Solution {
    public int search(int[] nums, int target) {
       int len=nums.length;
       int i=0,j=len-1;
       while(i<=j){
           int mid=i+(j-i)/2;
           if(nums[mid]==target) return mid;
           if(nums[mid]>=nums[i]){
               if(target>=nums[i]&&target<=nums[mid]){
                   j=mid-1;
               }else{
                   i=mid+1;
               }
           }else{
               if(target>=nums[mid]&&target<=nums[j]){
                   i=mid+1;
               }else{
                   j=mid-1;
               }
           }
       } 
       return -1;
    }
}
posted @   livingsu  阅读(8)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗
点击右上角即可分享
微信分享提示