美文网首页
2019-08-11 旋转数组中的最小数字

2019-08-11 旋转数组中的最小数字

作者: Reinelili | 来源:发表于2019-08-11 23:48 被阅读0次

旋转数组中的最小数字
题目描述
把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非减排序的数组的一个旋转,输出旋转数组的最小元素。 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。 NOTE:给出的所有元素都大于0,若数组大小为0,请返回0

解法1: 直接使用Arrays提供的排序方法(升序)重排,找到第一个元素即为最小数。
运行时间:337ms
占用内存:30092k

import java.util.ArrayList;
import java.util.Arrays;
public class Solution {
    public int minNumberInRotateArray(int [] array) {
        if(array.length == 0){
            return 0;
        }
        else{
            //1 直接用sort();
            //Arrays.sort(array); 
            //2 for
            int min = array[0];
            for(int i : array){
                if (min > i){
                    min = i;
                }
            }
            return min;
        }
    }
}

解法2: 使用最简单的for循环暴力寻找
运行时间:332ms
占用内存:28860k

import java.util.ArrayList;
import java.util.Arrays;
public class Solution {
    public int minNumberInRotateArray(int [] array) {
        if(array.length == 0){
            return 0;
        }
        else{
            //1 直接用sort();
            //Arrays.sort(array); 
            //2 for
            int min = array[0];
            for(int i : array){
                if (min > i){
                    min = i;
                }
            }
            return min;
        }
    }
}

解法3: 在两段范围内都是非降序,当不符合这个规律时,就找到了最小数字
运行时间:265ms
占用内存:28136k

import java.util.ArrayList;
import java.util.Arrays;
public class Solution {
    public int minNumberInRotateArray(int [] array) {
        if(array.length == 0){
            return 0;
        }
        else{
            int min = array[0];
            for(int i = 0; i<array.length-1; i++){
                if (array[i] > array[i+1]){
                    min = array[i+1];
                }
            }
            return min;
        }
    }
}

虽然由于运算规模小,差别不是特别明显,但经过多次测试,使用这个分水岭寻找速度是最快。

下面,附上几个新学的方法

解法4 优先队列(自带排序)
运行时间:305ms
占用内存:30020k

import java.util.*;
public class Solution {
    public int minNumberInRotateArray(int [] array) {
        int n = array.length;
        if(n == 0){
            return 0;
        }
        PriorityQueue<Integer> queue = new PriorityQueue<>();
        for(int i = 0;i<n;i++){
            queue.add(array[i]);
        }
        return queue.poll();
    }
}

相关文章

  • [剑指offer]08-旋转数组的最小数字

    旋转数组的最小数字 题目 给定一个递增的旋转数组A,返回旋转数组中的最小值。旋转数组:给定一个已排序的数组,假设为...

  • 剑指offer——JAVA版

    Array 数组题目汇总[18题] [剑指offer] 二维数组中的查找 [剑指offer] 旋转数组的最小数字 ...

  • 剑指Offer——用两个栈来实现队列和旋转数组的最小数字

    用两个栈来实现队列 两个栈来实现一个队列github地址 旋转数组的最小数字 旋转数组的最小数字github地址

  • 旋转数组中的元素查找

    一、旋转数组中的最小数字 题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增排序...

  • 2019-08-11 旋转数组中的最小数字

    旋转数组中的最小数字题目描述把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非减排序的...

  • 旋转数组最小的数字

    题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非递减排序的数组的一个旋转,输出...

  • LeetCode 每日一题 [46] 旋转数组的最小数字

    LeetCode 旋转数组的最小数字 [简单] 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。...

  • 「算法」旋转数组的最小数字

    0006 旋转数组的最小数字 题目描述 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一...

  • 旋转数组中的最小数字

    题目描述 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个非递减排序的数组的一个旋转,输...

  • 11:旋转数组的最小数字

    题目11:旋转数组的最小数字 把一个数组最开始的若干个元素搬到数组的末尾, 我们称之数组的旋转。输入一个递增排序的...

网友评论

      本文标题:2019-08-11 旋转数组中的最小数字

      本文链接:https://www.haomeiwen.com/subject/tpkejctx.html