java刷题--33搜索旋转排序数组

Posted Anrys

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java刷题--33搜索旋转排序数组相关的知识,希望对你有一定的参考价值。

java刷题--33搜索旋转排序数组

题目

本题意在用二分法完成,直接遍历也可。但是就失去意义了。
在这里插入图片描述

代码

class Solution {
    public int search(int[] nums, int target) {
        int len = nums.length;
        int left = 0, right = len-1;
        while(left <= right){
            int mid = (left + right) / 2;
            if(nums[mid] == target) return mid;  //最终输出    
            //mid到right是升序         
            else if(nums[mid] < nums[right]){ 
                if(nums[mid] < target && target <= nums[right])  
                //如果target在mid到right区间
                    left = mid+1;
                else right = mid-1;  //target在0到mid区间    
                    
            }
            //0到mid是升序
            else if(nums[mid] >= nums[right]){                
                if(nums[left] <= target && target < nums[mid])
                    right = mid-1;
                else left = mid+1; //target在mid到right区间                
            }
        }
        return -1;
    }
}

结果

在这里插入图片描述

以上是关于java刷题--33搜索旋转排序数组的主要内容,如果未能解决你的问题,请参考以下文章

[leetcode] 33. 搜索旋转排序数组(Java)

LeetCode——日常刷题

java刷题--153寻找旋转排序数组中的最小值

LeetCode 33 搜索旋转排序数组(Java)

算法刷题-搜索旋转排序数组路径总和 II拆分数字

202004leetcode刷题记录