Leetcode33 搜索旋转排序数组

题解:

复制代码
/**
 * 旋转排序数组可分为N1 + N2两个部分,如:[4,5,6,7,1,2,3],N1为[4,5,6,7],N2为[1,2,3]
 *
 * 必然满足以下两个条件:
 * 1. N1和N2都是分别递增的;
 * 2. N1中的所有元素大于N2中的所有元素;
 *
 * 以上两个条件可推出:nums[0]是N1中最小的数,即nums[0] > N2中的所有元素
 *
 * 而mid不是在N1内就是在N2内,如果在N1内,则在N1内使用二分查找,否则在N2内使用二分查找
 * 所以:如果nums[0] <= nums[mid],即mid落在了N1内,则[0, mid]肯定是有序的
 *       否则mid落在了N2内,则[mid, n)肯定是有序的
 *
 */
if (nums[0] <= nums[mid]) {
    // 左半边有序
} else {
    // 右半边有序
}

先判断nums[mid]是在旋转数组的左半边,还是右半边;

如果在左半边然后使用target和nums[0]和nums[mid]作比较,target处于[0,mid]中间,right = mid - 1; else left = mid + 1;

如果在右半边,使用target和nums[mid] nums[nums.length-1]作比较,target处于[mid,nums[nums.length-1]], left = mid + 1,否则right = mid-1

代码

java 复制代码
public int search(int[] nums, int target) {

    if(nums.length == 0){
        return -1;    
    }
    int left = 0, right = nums.length - 1;
    while(left <= right){
        int mid = left + (right - left) / 2;
        if(nums[mid] == target){
            return mid;
        }
        //左半边有序,在左半边使用二分查找
        if(nums[mid] >= nums[0]){
            if(nums[0] <= target && target < nums[mid]){ //target处于[0,mid),向左移动mid            right = mid - 1;
                
            }
            else{
               left = mid + 1;
            }
        }
        //右半边有序,在右半边使用二分查找
        else{
            if(nums[mid] < target && target <= nums[nums.length - 1]){
                left = mid + 1;
            }
            else{
                right = mid - 1;
            }
        }
    }
    return -1;

}
相关推荐
AI科技星40 分钟前
张祥前统一场论:引力场与磁矢势的关联,反引力场生成及拉格朗日点解析(网友问题解答)
开发语言·数据结构·经验分享·线性代数·算法
C雨后彩虹41 分钟前
最少交换次数
java·数据结构·算法·华为·面试
-森屿安年-1 小时前
二叉平衡树的实现
开发语言·数据结构·c++
稚辉君.MCA_P8_Java1 小时前
Gemini永久会员 Go 返回最长有效子串长度
数据结构·后端·算法·golang
TL滕1 小时前
从0开始学算法——第五天(初级排序算法)
数据结构·笔记·学习·算法·排序算法
Ayanami_Reii1 小时前
进阶数据结构应用-线段树扫描线
数据结构·算法·线段树·树状数组·离散化·fenwick tree·线段树扫描线
浅川.251 小时前
xtuoj 素数个数
数据结构·算法
少许极端2 小时前
算法奇妙屋(十五)-BFS解决边权为1的最短路径问题
数据结构·算法·bfs·宽度优先·队列·图解算法·边权为1的最短路径问题
不穿格子的程序员3 小时前
从零开始写算法——普通数组类题:数组操作中的“翻转技巧”与“前后缀分解”
数据结构·算法
curry____3033 小时前
study in PTA(高精度算法与预处理)(2025.12.3)
数据结构·c++·算法·高精度算法