HOT100题打卡第36天——二分查找

153. 寻找旋转排序数组中的最小值

已知一个长度为 n 的数组,预先按照升序排列,经由 1n旋转 后,得到输入数组。例如,原数组 nums = [0,1,2,4,5,6,7] 在变化后可能得到:

  • 若旋转 4 次,则可以得到 [4,5,6,7,0,1,2]
  • 若旋转 7 次,则可以得到 [0,1,2,4,5,6,7]

注意,数组 [a[0], a[1], a[2], ..., a[n-1]] 旋转一次 的结果为数组 [a[n-1], a[0], a[1], a[2], ..., a[n-2]]

给你一个元素值 互不相同 的数组 nums ,它原来是一个升序排列的数组,并按上述情形进行了多次旋转。请你找出并返回数组中的 最小元素

你必须设计一个时间复杂度为 O(log n) 的算法解决此问题。


分析题目

还是要用二分法来解决这道题,难点是,中点的作用是什么,原数组是升序数组,第一个元素就是最小数,因为数组旋转被分成了两个升序的子数组,所以数组的最小值被旋转到了中间成为了断点导致数组无序,中点会把数组分成两段,一段有序一段无序,最小值就在无序的一段中,所以只需要在无序的一段中通过二分查找,不断缩小范围,直到左右指针合并,此时得到的就是导致无序的数,也就是最小值

代码

java 复制代码
class Solution {
    public int findMin(int[] nums) {
        int left = 0;
        int right = nums.length - 1;
        int mid;
        while (left < right) {
            mid = left + (right - left) / 2;

            if (nums[mid] > nums[right]) {
                left = mid + 1;

            } else {
                right = mid;
            }
        }

        return nums[left];

    }
}
相关推荐
2401_89148217几秒前
C++中的状态模式
开发语言·c++·算法
Magic--6 分钟前
选择排序:原理、实现与优化
数据结构·算法·排序算法
qq_417695059 分钟前
基于C++的区块链实现
开发语言·c++·算法
We་ct11 分钟前
LeetCode 74. 搜索二维矩阵:两种高效解题思路
前端·算法·leetcode·矩阵·typescript·二分查找
2401_8942419212 分钟前
基于C++的反射机制探索
开发语言·c++·算法
cui_ruicheng15 分钟前
C++ 数据结构进阶:unordered_map 与 unordered_set源码分析与实现
数据结构·c++·算法·哈希算法
C蔡博士19 分钟前
最小生成树(MST)详解:定义、算法与核心性质
算法·贪心算法·图论·时间复杂度
sxtyjty22 分钟前
AtCoder Beginner Contest 450 G题题解
数学·算法·期望
ccLianLian25 分钟前
数论·快速幂和逆元
数据结构·算法
没头脑的男大27 分钟前
华为题目152乘积最大子数组
算法·华为