阵列中的最小最大

哈利

因此,我编写了一个程序,该程序可以找到五个数字集的最大值和最小值。它在大多数情况下都有效,但是当我输入一组数字,例如{5,6,7,8,9}时,它将输出9作为最大值,但输出0作为最小值。任何想法或建议。导入java.util.Scanner;

public class MinMax {
  public static void main (String [] args) {
  @SuppressWarnings("resource")
  Scanner in = new Scanner (System.in);
  final int NUM_ELEMENTS = 5;
  double[] userVals = new double[NUM_ELEMENTS];
  int i = 0;
  double max = 0.0;
  double min = 0.0;

  System.out.println("Enter five numbers.");
  System.out.println();

  while (i < NUM_ELEMENTS) {
      System.out.println("Enter next number: ");
      userVals[i] = in.nextDouble();
      i++;
      System.out.println();
  }

  for (i = 0; i < userVals.length; i++) {
     if (userVals[i] > max) {
         max = userVals[i];
     }
         else if (userVals[i] < min) {
             min = userVals[i];
     }
  }
  System.out.println("Max number: " + max);
  System.out.println("Min number: " + min);
}

}

艾略特·新鲜

将您的默认值min设置为超出范围的数字(如Double.MAX_VALUE),并设置maxDouble.MIN_VALUE您还可以通过删除第二个循环来简化代码。您可以在一个循环中执行逻辑,也可以使用Math.max(double, double)Math.min(double, double)就像是,

Scanner in = new Scanner(System.in);
final int NUM_ELEMENTS = 5;
double[] userVals = new double[NUM_ELEMENTS];
System.out.println("Enter five numbers.");
System.out.println();
double min = Double.POSITIVE_INFINITY;
double max = Double.NEGATIVE_INFINITY;
for (int i = 0; i < NUM_ELEMENTS; i++) {
    System.out.println("Enter next number: ");
    userVals[i] = in.nextDouble();
    min = Math.min(min, userVals[i]);
    max = Math.max(max, userVals[i]);
}
System.out.println("Max number: " + max);
System.out.println("Min number: " + min);

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章