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];

    }
}
相关推荐
小草cys1 分钟前
基于大模型的图像目标检测及跟踪算法
人工智能·算法·目标检测
Tingjct9 分钟前
【C语言实现堆的TOPK问题】——海量数据中怎么找前K大(小)?
数据结构
代码游侠13 分钟前
C语言核心概念复习(三)
开发语言·数据结构·c++·笔记·学习·算法
池央19 分钟前
贪心算法-递增的三页子序列
算法·贪心算法
lrh12280020 分钟前
详解K近邻(KNN)算法:原理、实现与优化
算法·机器学习
程途拾光15828 分钟前
算法公平性:消除偏见与歧视的技术探索
大数据·人工智能·算法
秋风战士29 分钟前
无线通信算法之340:信道均衡除法定标讨论
算法·fpga开发·信息与通信
沧澜sincerely32 分钟前
蓝桥杯算法练习
算法·职场和发展·蓝桥杯
一起养小猫35 分钟前
Flutter for OpenHarmony 进阶:手势识别与碰撞检测算法深度解析
算法·flutter·harmonyos
Herbert_hwt37 分钟前
数据结构与算法绪论:为何学、学什么、如何避坑
c语言·数据结构·算法