5.例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1

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

例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。


个人感觉方法有点笨,不知道有没有其他办法,欢迎留言

import java.util.ArrayList;
public class Solution {
    public int minNumberInRotateArray(int [] array) {
        int length = array.length;
    	if(length==0){
            return 0;
        }
        int[] newArray = new int[length];
        int i = 0;
        int j = 0;
        while(array[i]<=array[i+1]){
            i++;
        }
        int k = i+1;
        while(k<length){
            newArray[j]=array[k];
            j++;
            k++;
        }
        int m = 0;
        while(m<i){
            newArray[j]=array[m];
            m++;
        }
        return newArray[0];
    }
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
数组是用来存放一组具有相同类型数据的数据结构。可以通过整型下标来访问数组中的 每一个值。数组是可以通过在某种数据类型后面加上[]来定义,在此之后跟上变量名就可以 定义相应类型的数组变量了。例如: int[] a; 还可以使用另一种方法定义数组,例如: int a[]; 以上这两种方法的定义是等价的。在这里只定义了一个整型数组变量 a,但是还没有将 a 真正的初始化为一个数组。为将一个数组初始化可以使用 new 关键字,也可以使用赋值语 句进行初始化。数组一旦被创建,就不能改变它的大小。 例如: a = new int[10]; //将 a 初始化为大小为 10 的整型数组。 int[] b = {0,1,2,3} //将 b 初始化为大小为 4 的整型数组, //并且 4 个分量的值分别等于 0,1,2,3 数组的下标从 0 开始计数,到数组大小减 1 结束。在 Java 中不能越过数组下标的范围 去访问数组中的数据。例如: a[10] = 10; 如果越过数组的下标访问数据,则会产生一个名为 ArrayIndexOutOfBoundsException 的 运行时错误。为避免产生这种错误,可以通过在访问某个下标的数组元素前检查数组的大小 来避免。数组的大小可以通过数组的变量 length 返回。例如: for (int i=0;i<a.length;i++) a[i] = i; 由于在 Java 中数组实际上是一个类,因此两个数组变量可以指向同一个数组。请读者 5 预测以下这段代码的运行结果: int[] a = {1,1,1}; int[] b = a; for (int i=0;i<b.length;i++) b[i]++; for (int i=0;i<a.length;i++) System.out.print(a[i]); 在这段代码中对数组 b 的每个分量加 1,但是在输出数组 a 的每个分量时,可以发现 a 的每个分量都发生了变化,都为 2。其原因是赋值语句 int[] b = a; 只是将对于数组 a 的引用 传递给变量 b,此时数组变量 a、b 实际上是指向同一个数组空间。图 1-2 说明了这段代码运 行时的情况。 图 1-2 两个数组变量指向同一数组空间 int[] a = {1,1,1}; a int[] b = a; 1 1 1 a b for (int i=0;i<b.length;i++) b[i]++; 1 1 1 2 2 2 a b for (int i=0;i<a.length;i++) System.out.print(a[i]); 输出:222 为了得到两个不同的但每个分量的值均相等的数组,可以使用循环语句或 System 类中 的 arraycopy 方法来完成。 同样当数组作为方法的参数传递时,也是传递的对于数组的引用,因此在方法中对数组 进行的操作会影响到原来的数组。例如: public void changeArray(int[] a){ for (int i=0;i<a.length;i++) a[i] = a[i] * 2; } 那么如下代码 int c = {2,2,2}; changeArray( c ); 6 for (int i=0;i<c.length;i++) System.out.print(c[i]); 的运行结果为:444。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值