【LeetCode:153. 寻找旋转排序数组中的最小值 + 二分】

时间:2024-11-05 08:56:10

在这里插入图片描述在这里插入代码片

???? 算法题 ????

???? 算法刷题专栏 | 面试必备算法 | 面试高频算法 ????
???? 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨
???? 作者简介:硕风和炜,****-Java领域优质创作者????,保研|国家奖学金|高中学习JAVA|大学完善JAVA开发技术栈|面试刷题|面经八股文|经验分享|好用的网站工具分享????????????
???? 恭喜你发现一枚宝藏博主,赶快收入囊中吧????
???? 人生如棋,我愿为卒,行动虽慢,可谁曾见我后退一步?????????

???? 算法题 ????

在这里插入图片描述

在这里插入图片描述

???? 目录

    • ???? 题目链接
    • ⛲ 题目描述
    • ???? 求解思路&实现代码&运行结果
      • ⚡ 二分
        • ???? 求解思路
        • ???? 实现代码
        • ???? 运行结果
    • ???? 共勉

???? 题目链接

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

⛲ 题目描述

已知一个长度为 n 的数组,预先按照升序排列,经由 1 到 n 次 旋转 后,得到输入数组。例如,原数组 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) 的算法解决此问题。

示例 1:

输入:nums = [3,4,5,1,2]
输出:1
解释:原数组为 [1,2,3,4,5] ,旋转 3 次得到输入数组。
示例 2:

输入:nums = [4,5,6,7,0,1,2]
输出:0
解释:原数组为 [0,1,2,4,5,6,7] ,旋转 3 次得到输入数组。
示例 3:

输入:nums = [11,13,15,17]
输出:11
解释:原数组为 [11,13,15,17] ,旋转 4 次得到输入数组。

提示:

n == nums.length
1 <= n <= 5000
-5000 <= nums[i] <= 5000
nums 中的所有整数 互不相同
nums 原来是一个升序排序的数组,并进行了 1 至 n 次旋转

???? 求解思路&实现代码&运行结果


⚡ 二分

???? 求解思路
  1. 判断nums[mid] 和数组最小值的位置关系,nums[mid] 是现在二分取到的数,如果 x>nums[n−1],那么nums 一定被分成左右两个递增段,第一段的所有元素均大于第二段的所有元素;最小值在第二段。
  2. 如果 nums[mid] ≤ nums[n−1],那么最小值在第一段。
  3. 有了基本的思路,接下来我们就来通过代码来实现一下。
???? 实现代码
class Solution {
    public int findMin(int[] nums) {
        int n = nums.length;
        int left = -1, right = n - 1;
        while (left + 1 < right) {
            int mid = left + right >> 1;
            if (nums[mid] <= nums[n - 1]) {
                right = mid;
            } else {
                left = mid;
            }
        }
        return nums[right];
    }
}
???? 运行结果

在这里插入图片描述


???? 共勉

最后,我想和大家分享一句一直激励我的座右铭,希望可以与大家共勉!

在这里插入图片描述

在这里插入图片描述