繁体   English   中英

在Java中随机生成的数组中找到第二高的数字

[英]finding the secondhighest number in a randomly generated array in java

大家好,我遇到一个作业问题,要求我找到随机生成的数组的第二高数字并返回该数字。 该数组的长度必须为6,因此从概念上讲,这是我遇到编译器错误墙之前的内容。 有人可以帮我完成吗? 更新:我需要引用数组,并在主要方法中调用它,试图在system.out.println语句中这样做,但是我不知道如何调用适当的方法/数组。

import java.io.*;
import java.util.Arrays; 

public class SecondHighest{
 public static int find2ndHighest(int[] list){
//define how long the array can be
list[] = new int[6];
    //create a for loop to fill the array.
for(int i = 0; i>=list.length; i++){
  list[i] = (int)(Math.random()*10);

}
  Arrays.sort(list);    //use the built-in sorting routine
  return list[1];

}
}

您的循环永远无法正常工作,因为i永远不会大于或等于 list.length

更改

for(int i = 0; i>=list.length; i++){

for(int i = 0; i<list.length; i++){

它应该小于,因为Array索引从零开始,以Arraylength-1结束

也改变

list[] = new int[6];// this is wrong 

 to 

list = new int[6]; // you dont need sqare brackets, you only need array reference.

阅读您的编译器错误! 有很多语法错误,例如在将其作为参数后调用list-> list []。 您可以称之为清单! 此外,您不必在方法内部创建新列表! 应该是这样的:

 import java.io.*;
    import java.util.Arrays; 

    public class SecondHighest{

     public static int find2ndHighest(int[] list){

        //create a for loop to fill the array.
    for(int i = 0; i<list.length; i++){
      list[i] = (int)(Math.random()*10);

    }
      Arrays.sort(list);    //use the built-in sorting routine
      return list[1];
    }

     //define how long the array can be
      int[] list = new int[6];
      int result = find2ndHighest(list);

    }

我不确定使用Math随机函数。

另外,考虑到这是一个家庭作业问题,最好不要对整个数组进行排序,因为这样会得到O(n * logn)复杂度,但是要遍历值并仅保留最大的两个值(n)复杂性。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM