搜索旋转排序数组:必有一侧是有序的

一、关键洞察

旋转数组的二分和普通二分只有一个区别:普通二分我们知道整个数组有序,旋转数组中必有一侧是有序的

判断哪一侧有序,然后看 target 是否在这一侧。


二、代码实现

javascript 复制代码
var search = function(nums, target) {
    let left = 0, right = nums.length - 1;
    while (left <= right) {
        const mid = left + Math.floor((right - left) / 2);
        if (nums[mid] === target) return mid;
        
        if (nums[left] <= nums[mid]) {
            if (nums[left] <= target && target < nums[mid]) {
                right = mid - 1;
            } else {
                left = mid + 1;
            }
        } else {
            if (nums[mid] < target && target <= nums[right]) {
                left = mid + 1;
            } else {
                right = mid - 1;
            }
        }
    }
    return -1;
};

三、关键细节

nums[left] <= nums[mid] 判断左侧是否有序。如果左侧有序且 target 在 left 到 mid 之间,收缩到左侧,否则去右侧。

nums[left] > nums[mid] 时,左侧无序则右侧一定有序,同理处理。

<= 而不是 <------当 left === mid 时,nums[left] <= nums[mid] 为 true,左侧被判定为有序(一个元素天然有序)。


四、复杂度

O(log n) 时间,O(1) 空间。


五、总结

  1. 旋转数组二分的关键:必有一侧有序
  2. 判断哪一侧有序,再判断 target 是否在其中
  3. 和普通二分的区别只多了一个条件分支
  4. 不包含重复数字时,numsleft <= numsmid 即可判断
相关推荐
用户484526255821 小时前
翻转二叉树:前序和后序的写法完全一样
排序算法
用户484526255821 小时前
对称二叉树:左子树的左和右子树的右对比
排序算法
啵啵啵鱼6 天前
数组---完
算法·排序算法
嘿黑嘿呦6 天前
chap 8排序
算法·蓝桥杯·排序算法·软件工程
小糯米6016 天前
JS 数组
数据结构·算法·排序算法
孬甭_7 天前
深入解析归并排序:稳定高效的分治典范
算法·排序算法
北域码匠7 天前
奇偶归并排序:并行计算的排序利器
数据结构·算法·c#·排序算法
2601_961845157 天前
花生十三网课网盘|百度网盘|下载
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划
ruxshui7 天前
排序算法及不同场景应用总结
算法·排序算法