博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
154. Find Minimum in Rotated Sorted Array II
阅读量:4974 次
发布时间:2019-06-12

本文共 1478 字,大约阅读时间需要 4 分钟。

题目:

Follow up for "Find Minimum in Rotated Sorted Array":

What if duplicates are allowed?

Would this affect the run-time complexity? How and why?

Suppose a sorted array is rotated at some pivot unknown to you beforehand.

(i.e., 0 1 2 4 5 6 7 might become 4 5 6 7 0 1 2).

Find the minimum element.

The array may contain duplicates.

链接: 

题解:

find min in rotated sorted array ii, 这道题目是上道题的follow up,包括了数组中有重复数字的情况。主要思路和Search in Rotated Sorted Array一样,可以使用Decision Tree决策树,划分清楚每种条件,然后解题。 这里可以先判定nums[lo] < nums[hi]时,nums[lo]为最小值,接下来根据nums[mid]与nums[hi]的关系来决定并且update min。其实还能再写得简洁一些。

Time Complexity - O(n),Space Complexity - O(1)。

public class Solution {    public int findMin(int[] nums) {        if(nums == null || nums.length == 0)            return Integer.MAX_VALUE;        int lo = 0, hi = nums.length - 1, min = Integer.MAX_VALUE;                while(lo <= hi) {            if(nums[lo] < nums[hi])                return nums[lo];            else {                int mid = lo + (hi - lo) / 2;                if(nums[mid] < nums[hi]) {                    min = Math.min(nums[mid], min);                    hi = mid;                } else if(nums[mid] > nums[hi]) {                    min = Math.min(nums[hi], min);                    lo = mid + 1;                } else {                    min = Math.min(nums[mid], min);                    hi--;                }            }        }                return min;    }}

 

测试:

转载于:https://www.cnblogs.com/yrbbest/p/4489694.html

你可能感兴趣的文章
Android studio怎么修改文件名
查看>>
sass学习笔记-安装
查看>>
多缓存并存
查看>>
Flask (二) cookie 与 session 模型
查看>>
修改添加网址的教程文件名
查看>>
hdu 1045:Fire Net(DFS经典题)
查看>>
[BZOJ 1017][JSOI2008]魔兽地图DotR(树形Dp)
查看>>
裁剪图片
查看>>
数据结构实习 problem L 由二叉树的中序层序重建二叉树
查看>>
VS中展开和折叠代码
查看>>
如何确定VS编译器版本
查看>>
设置PL/SQL 快捷键
查看>>
个人阅读作业7
查看>>
转载:深入浅出Zookeeper
查看>>
GMA Round 1 新程序
查看>>
node anyproxy ssi简易支持
查看>>
编译预处理指令:文件包含指令、宏定义指令、条件编译指令
查看>>
PHP函数 ------ ctype_alnum
查看>>
网站安全
查看>>
WS-Addressing 初探
查看>>