33. 搜索旋转排序数组

33. 搜索旋转排序数组

转化为两次二分。

java 复制代码
class Solution {
    public int search(int[] nums, int target) {
        int l = 0, r = nums.length - 1;

        // 找到分隔点,大于nums[0]的最后一个数(最大的数)
        while(l < r){
            int mid = l + r + 1 >> 1;
            if(nums[0] > nums[mid]) r = mid - 1;
            else l = mid;
        }

        if(nums[0] > target) r = nums.length - 1;
        else l = 0;

        // 在有序数组中找目标值
        while(l < r){
            int mid = l + r + 1 >> 1;
            if(nums[mid] > target) r = mid - 1;
            else l = mid;
        }

        return nums[l] == target ? l : -1;
    }
}
相关推荐
G***669128 分钟前
算法设计模式:贪心与动态规划
算法·设计模式·动态规划
墨染点香43 分钟前
LeetCode 刷题【160. 相交链表】
算法·leetcode·链表
少睡点觉43 分钟前
LeetCode 238. 除自身以外数组的乘积 问题分析+解析
java·算法·leetcode
大千AI助手1 小时前
多叉树:核心概念、算法实现与全领域应用
人工智能·算法·决策树·机器学习··多叉树·大千ai助手
一只老丸1 小时前
HOT100题打卡第38天——贪心算法
算法·贪心算法
普通网友1 小时前
高性能TCP服务器设计
开发语言·c++·算法
醒过来摸鱼1 小时前
9.12 sinc插值
python·线性代数·算法·numpy
普通网友1 小时前
C++与硬件交互编程
开发语言·c++·算法
liliangcsdn1 小时前
EnsembleRetriever中的倒数融合排序算法
算法·排序算法
HUTAC1 小时前
重要排序算法(更新ing)
数据结构·算法