IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 剑指offer 11. 旋转数组的最小数字(很详细!) -> 正文阅读

[数据结构与算法]剑指offer 11. 旋转数组的最小数字(很详细!)

剑指offer 11. 旋转数组的最小数字

题目

题目详细

解题思路

一开始,我们就能直接想到,数组找最小值,那么不轻轻松松直接遍历一遍,用一个变量记录最小值,然后直接返回不就完事了?
但是这样做真的不优雅!!!,因为题目已经说了是一个旋转的数组,直接遍历暴力,那么题目还要说旋转干嘛呢?
所以这里我们需要具体分析一下可以包含重复元素的数组旋转过后会是什么情况
旋转过后基本上是这种图案:最小值大概位于中间位置(这里偷点懒直接用了力扣官方的图片,懒得画图了😁)
在这里插入图片描述
注意到,旋转数组中的最后一个值x, 在最小值右侧的值都小于等于x,在最小值左侧的值都大于等于x,因此根据这一条性质,我们可以使用二分查找找出数组中的最小值

我们将在二分查找的每一步中,左边界为 low,右边界为high,区间的中点为 pivot,最小值就在该区间内。

我们将中轴元素 numbers[pivot]与右边界元素 numbers[high] 进行比较,可能会有以下的三种情况:

  • 1.第一种情况是numbers[pivot] < numbers[high] 那么就是这样的
    第一种情况
    说明最小值位于pivot的左边那么我们可以将右边界high缩小为pivot所指的地方high = pivot

  • 第二种情况 numbers[pivot] > numbers[high] ,那么就是这样
    在这里插入图片描述
    说明numbers[pivot]是最小值左侧的元素我们将low更新为 pivot + 1
    low = povit + 1
    这里说明一下为什么是更新为povit + 1 而上面的情况是更新为povit
    因为numbers[pivot] > numbers[high]时,pivot只可能在最小值左侧,pivot+1最大只能是最小值的位置。但是,numbers[pivot] < numbers[high]时,pivot既可能刚好是最小值,也可能在最小值右侧,如果刚好是最小值的话,pivot-1就错过了最小值.

  • 第三种情况是 numbers[pivot] == numbers[high] :
    由于数组中可能存在重复的元素那么可能的情况是这样的
    第三章情况
    由于数组中可能存在重复的元素,我们无法确定pivot是位于最小值的左侧还是右侧.所以我们不能莽撞的去忽略任何一部分的值.但是我们唯一可以确认的是
    不管high指向的值是不是最小值,我们都有一个替代值就是pivot.
    所以我们可以忽略右端点
    即 : high--
    知道了思路我们就可以写代码了

代码

func minArray(numbers []int) int {
	low := 0
	high := len(numbers) - 1
	for low < high {
		povit := low + (high - low)/2
		if numbers[pivot] < numbers[high] {
			high = pivot
		}else if numbers[pivot] > numbers[high]{
			low = pivot + 1
		}else {
			high--
		}
	}
	return numbers[low]
}

时间复杂度 : O(logn) n为numbers的长度,特殊案例时[1,1,1,1]会退化为O(n)
要遍历n次
空间复杂度 : O(1) : low,high,pivot变量使用常数大小的额外空间。
这里使用的是go语言写的,其他语言也差不多啦,解题思路都是一样的

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-08-20 15:22:16  更:2021-08-20 15:22:27 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/28 17:00:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计