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

    }
}
相关推荐
leiming66 小时前
C++ 类模板对象做函数参数
开发语言·c++·算法
王老师青少年编程6 小时前
csp信奥赛C++标准模板库STL案例应用1
c++·算法·stl·标准模板库·csp·信奥赛·binary_search
NAGNIP6 小时前
Kimi Linear——有望替代全注意力的全新注意力架构
算法·面试
耶叶6 小时前
B树知识点总结
数据结构·b树
智驱力人工智能7 小时前
无人机河道漂浮物检测 从项目构建到价值闭环的系统工程 无人机河道垃圾识别 农村河道漂浮物智能清理方案 无人机辅助河道清洁预警
opencv·算法·安全·yolo·目标检测·无人机·边缘计算
德福危险7 小时前
C语言数据类型与变量 系统总结笔记
c语言·笔记·算法
@淡 定7 小时前
JVM调优参数配置详解
java·jvm·算法
CoovallyAIHub7 小时前
从电影特效到体育科学,运动追踪只能靠“人眼”吗?
深度学习·算法·计算机视觉
风筝在晴天搁浅7 小时前
hot100 48.旋转图像
算法
TechNomad7 小时前
排序算法:希尔排序算法
数据结构·算法·排序算法