leetcode 153. 寻找旋转排序数组中的最小值(优质解法)

2023-12-15 14:28

本文主要是介绍leetcode 153. 寻找旋转排序数组中的最小值(优质解法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

代码:

class Solution {public int findMin(int[] nums) {int left=0,right=nums.length-1;int refer=nums[right];while (left<right){int mid=left+(right-left)/2;if(nums[mid]>refer){left=mid+1;}else {right=mid;}}return nums[left];}
}

题解:

        通过题意我们知道,传入的参数是经过旋转的递增数组,如 3,4,5,1,2,就是通过 1,2,3,4,5 旋转得到的,而这种旋转数组的特性我们可以通过一张图清晰的看出来,以 3,4,5,1,2 为例


        我们可以看出旋转以后的递增数组大多呈现这样的结构,我们将数据分为了两个区间,而需要获取的答案位于下面区间的左边界

        我们可以以数组的最后一个数据作为 refer 参照,在数组中选取一个数 nums[ i ],这个数可能会位于上面和下面两个区间

        (1).当 nums[ i ] > refer 时,说明该数位于上面的区间,那我们就可以大胆去除掉 i 下标指向的数据以及左边的数据

        (2).当 nums[ i ] <= refer 时,说明该数位于下面的区间,那我们就可以大胆去除掉 i 下标右边的数据(但我们不能确定 i 下标指向的是否刚好是我们需要的数据,所以我们不能去除掉 i 下标指向的数据)

        通过上面的分析,我们已经能够确定,该题目具有二段性,所以我们可以通过二分法来解决该问题

        以 nums = 3,4,5,1,2 为例,用 L 和 R 指针指向数组的两端,mid = left+(right-left)/2= 2 .此时 R 指针指向的刚好是数组的最后一个数据,我们可以顺便记录起来,作为参照值,refer = nums[ R ] = 2

        此时 nums[ mid ] = 5 > refer,所以在上面的区间,我们就可以大胆去除 mid 指针以及 mid 指针左边的数据,让 L = mid+1

3        4        5        1        2

L                 mid               R

        计算中间值 mid = 3,此时 nums[ mid ] = 1 < refer, 所以在下面的区间,我们就可以大胆去除 mid 右边的数据,让 R =mid 

3        4        5        1        2

                               L       R

                              mid 

        当 L 和 R 指针相遇时,我们便找到了下面区间的左边界,直接返回 nums[ L ] 即可

3        4        5        1        2

                               L       

                               R

这篇关于leetcode 153. 寻找旋转排序数组中的最小值(优质解法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/496755

相关文章

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c

hdu2241(二分+合并数组)

题意:判断是否存在a+b+c = x,a,b,c分别属于集合A,B,C 如果用暴力会超时,所以这里用到了数组合并,将b,c数组合并成d,d数组存的是b,c数组元素的和,然后对d数组进行二分就可以了 代码如下(附注释): #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<que

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

poj 3974 and hdu 3068 最长回文串的O(n)解法(Manacher算法)

求一段字符串中的最长回文串。 因为数据量比较大,用原来的O(n^2)会爆。 小白上的O(n^2)解法代码:TLE啦~ #include<stdio.h>#include<string.h>const int Maxn = 1000000;char s[Maxn];int main(){char e[] = {"END"};while(scanf("%s", s) != EO

hdu 1166 敌兵布阵(树状数组 or 线段树)

题意是求一个线段的和,在线段上可以进行加减的修改。 树状数组的模板题。 代码: #include <stdio.h>#include <string.h>const int maxn = 50000 + 1;int c[maxn];int n;int lowbit(int x){return x & -x;}void add(int x, int num){while

hdu 1285(拓扑排序)

题意: 给各个队间的胜负关系,让排名次,名词相同按从小到大排。 解析: 拓扑排序是应用于有向无回路图(Direct Acyclic Graph,简称DAG)上的一种排序方式,对一个有向无回路图进行拓扑排序后,所有的顶点形成一个序列,对所有边(u,v),满足u 在v 的前面。该序列说明了顶点表示的事件或状态发生的整体顺序。比较经典的是在工程活动上,某些工程完成后,另一些工程才能继续,此时

poj 3258 二分最小值最大

题意: 有一些石头排成一条线,第一个和最后一个不能去掉。 其余的共可以去掉m块,要使去掉后石头间距的最小值最大。 解析: 二分石头,最小值最大。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <c

poj 2187 凸包or旋转qia壳法

题意: 给n(50000)个点,求这些点与点之间距离最大的距离。 解析: 先求凸包然后暴力。 或者旋转卡壳大法。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <s

leetcode-24Swap Nodes in Pairs

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode swapPairs(L