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;
    }
}
相关推荐
Chase_______几秒前
LeetCode 1493 & 3634 题解:滑动窗口双指针,从“删一个元素的全1子数组“到“最少移除使数组平衡“
算法·leetcode
悲伤小伞13 分钟前
LeetCode 热题 100_4-283. 移动零
算法·leetcode·职场和发展
星 海18 分钟前
网络芯片对IP地址最长前缀匹配算法的实现
网络·算法
OYangxf19 分钟前
力扣hot100【滑动窗口】
算法·leetcode·职场和发展
CQU_JIAKE29 分钟前
5.7【A】
算法
2zcode30 分钟前
基于SVM与HOG算法的行人检测系统设计与实现
算法·机器学习·支持向量机
MATLAB代码顾问34 分钟前
MATLAB实现粒子群算法优化PID参数
开发语言·算法·matlab
翎沣39 分钟前
C++11异常处理机制
java·c++·算法
火花怪怪44 分钟前
Origin分析外量子效率(EQE, External Quantum Efficiency)数据处理-EQE计算带隙
算法·数据分析
上弦月-编程1 小时前
异或法巧解数组中两独数
数据结构·算法