我是靠谱客的博主 受伤睫毛膏,最近开发中收集的这篇文章主要介绍6.剑指offer-旋转数组的最小数字(python版),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

6.剑指offer-旋转数组的最小数字(python版)
本题知识点: 查找
题目描述
把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素。例如,数组 [3,4,5,1,2] 为 [1,2,3,4,5] 的一个旋转,该数组的最小值为1。

示例 1:
输入:[3,4,5,1,2]
输出:1

示例 2:
输入:[2,2,2,0,1]
输出:0

解题思路
总体二分:
if mid大于high, low = mid - 1
if mid小于high, high = mid
直到mid=high,取此位置的数

排序数组的查找问题首先考虑使用 二分法 解决,其可将遍历法的 线性级别 时间复杂度降低至 对数级别 。

循环二分: 设置 ii, jj 指针分别指向 numbers 数组左右两端,m = (i + j) // 2m=(i+j)//2 为每次二分的中点( “//” 代表向下取整除法,因此恒有 i leq m < ji≤m<j ),可分为以下三种情况:
当 numbers[m] > numbers[j]时: mm 一定在 左排序数组 中,即旋转点 xx 一定在 [m + 1, j][m+1,j] 闭区间内,因此执行 i = m + 1i=m+1;
当 numbers[m] < numbers[j] 时: mm 一定在 右排序数组 中,即旋转点 xx 一定在[i, m][i,m] 闭区间内,因此执行 j = mj=m;
当 numbers[m] == numbers[j] 时: 无法判断 mm 在哪个排序数组中,即无法判断旋转点 xx 在 [i, m][i,m] 还是 [m + 1, j][m+1,j] 区间中。解决方案: 执行 j = j - 1j=j−1 缩小判断范围 (分析见以下内容) 。
返回值: 当 i = ji=j 时跳出二分循环,并返回 numbers[i] 即可。

代码如下:

class Solution:
def minArray(self, numbers: [int]) -> int:
i, j = 0, len(numbers) - 1
while i < j:
m = (i + j) // 2
if numbers[m] > numbers[j]: i = m + 1
elif numbers[m] < numbers[j]: j = m
else: j -= 1
return numbers[i]

最后

以上就是受伤睫毛膏为你收集整理的6.剑指offer-旋转数组的最小数字(python版)的全部内容,希望文章能够帮你解决6.剑指offer-旋转数组的最小数字(python版)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(55)

评论列表共有 0 条评论

立即
投稿
返回
顶部