【剑指offer】六,旋转数组中的最小数字

题目描述

把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。

分析:数组旋转后会变为一个局部有序的数组,分为两部分,都是递增的。查找最小元素,我们首先想到的时冒泡排序一遍,或者一趟选择排序。或者直接找出a[i]<a[i-1]的点即为要查找的点。也可利用折半查找,判断最小值所在的一侧。

 1 import java.util.ArrayList;
 2 public class Solution {
 3     public int minNumberInRotateArray(int[] array) {
 4         if(array==null||array.length==0){
 5             return 0 ;
 6         }
 7         if(array.length==1||array[0]<array[array.length-1]){
 8             return array[0] ;
 9         }
10         if(array.length==2){
11             return Math.min(array[0], array[1]) ;
12         }
13         int min = array[0] ;
14         for(int i = 1 ; i <array.length ;i++  ){
15             if(array[i]<min){
16                 min = array[i] ;
17             }
18         }
19         return min ;
20     }
21 }

第二种方法

import java.util.ArrayList;
public class Solution {
    public int minNumberInRotateArray(int [] array) {
        if (array.length == 0) return 0; ///not a[0]
        for (int i = 1; i < array.length; ++i) {
            if (array[i] < array[i - 1]) return array[i];
        }
        return array[0];
    }
}
时间: 2024-09-30 21:41:32

【剑指offer】六,旋转数组中的最小数字的相关文章

剑指Offer之旋转数组中的最小数字(题8)

1 /****************************************   2     > File Name:test.c   3     > Author:xiaoxiaohui   4     > mail:[email protected]   5     > Created Time:2016年05月23日 星期一 20时07分13秒   6 ****************************************/   7    8    9 

【剑指offer】旋转数组中的最小值

题目总结: 1.若没有进行旋转,或者说旋转后的效果跟没有旋转是一样的,那么index1指示的值小于index2指示的值,返回index1的值. 2.若是一般性的旋转,那么最小的值旋转后肯定在中间,那么我们就可以从两边向中间夹逼. 3.夹逼的过程中,若 [ index1, middle ] 是有序的,说明这部分子区间没被破坏,旋转所移动的元素都在middle 的后面,那么最小值可定也在后面的部分,令 index1 = middle,继续向后夹逼:同理,若 [ middle ,index2 ] 是有

剑指offer之【数组中重复的数字】

题目: 数组中重复的数字 链接: https://www.nowcoder.com/practice/623a5ac0ea5b4e5f95552655361ae0a8?tpId=13&tqId=11203&rp=3&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking 题目描述: 在一个长度为n的数组里的所有数字都在0到n-1的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不

【剑指Offer】03. 数组中重复的数字

题目链接 找出数组中重复的数字. 在一个长度为 n 的数组 nums 里的所有数字都在 0-n-1 的范围内.数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次.请找出数组中任意一个重复的数字. 示例 1: 输入: [2, 3, 1, 0, 2, 5, 3] 输出:2 或 3 限制: 2 <= n <= 100000 解法一:最简单的,排序后找重复的 class Solution { public int findRepeatNumber(int[] nums) {

《剑指offer》:[51]数组中的重复数字

题目:在一个长度为n的数组里所有数字都在0到n-1的范围里.数组中某些数字是重复的,但是不知道有几个数字重复了,也不知道每个数字重复几次.请找出数组中任意一个重复的数字.例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是重复的数字2或者3. 分析:其实这个题因为它的限制太多,这样是这个题失去了泛型,比如里面的数字的范围确定在0到n-1内,还有任意意对即可,不能对任意的数组进行查重操作.下面先来看看这个问题怎么解决吧! 方案一:时间复杂度为O(N*N)的顺序扫描法.从第一

剑指Offer面试题:6.旋转数组中的最小数字

一 题目:旋转数组中的最小数字 题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转.输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素.例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1. 这道题最直观的解法并不难,从头到尾遍历数组一次,我们就能找出最小的元素.这种思路的时间复杂度显然是O(n).但是这个思路没有利用输入的旋转数组的特性,肯定达不到面试官的要求. 我们注意到旋转之后的数组实际上可以划分为两个排序的子数组,而且前面的子数组

【剑指offer】旋转数组的最小数字

题目描述: 把一个数组最开始的若干个元素搬到数组的末尾,称之为数组的旋转.输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素.例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1. 分析描述: 求一个数组中的最小值,最简单的办法就是逐个比较数组中各个元素的值,遍历完整个数组,即可得数组中最小元素.但这种方法存在的问题是时间复杂度为O(n). 利用题目中给出的条件:递增排序数组的旋转.利用递增排序的特点,可以用二分查找方法实现时间复杂度为O(logn)的查找.

剑指offer (8) 旋转数组

1. 查找和排序 查找:顺序查找.二分查找.二叉搜索树.哈希表 顺序查找:T(n) = O(n)           std::find 二分查找:T(n) = O(log n)      std::binary_search  std::lower_bound  std::upper_bound 哈希表:   T(n) = O(1)           std::unordered_map 排序:快速排序.归并排序.堆排序.计数排序.冒泡排序 1 int Partition(std::vect

剑指OFFER之旋转数组的最小数字(九度OJ1386)

题目描述: 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转.输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素.例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1. 输入: 输入可能包含多个测试样例,对于每个测试案例, 输入的第一行为一个整数n(1<= n<=1000000):代表旋转数组的元素个数. 输入的第二行包括n个整数,其中每个整数a的范围是(1<=a<=10000000). 输出: 对应每个测试案例, 输出旋转数组

剑指Offer:旋转数组的最小数字【11】

剑指Offer:旋转数组的最小数字[11] 题目描述 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素. 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1. NOTE:给出的所有元素都大于0,若数组大小为0,请返回0. 解题分析 我们用两个坐标,Left,Right分别表示左右两个递增序列的下标,刚开始L为0,R为4: 当Arr[Mid]>Arr[Left],可以说明,Mid及左边构