java - 尝试确定 Java 数组中的最小数量和位置

标签 java

我是这个网站的新手,一般来说也是编程新手,所以请保持温和。我正在做一项任务,我已经构建了它需要的一切,但我在一个特定部分遇到了问题。

所以下面的代码只是我遇到问题的整个程序的 for 循环部分。我创建了一个数组来存储用户的季度输入。当我去确定哪个季度的降雨量最大时,代码没有问题。

然而,当我尝试确定金额最少的季度时,我遇到了问题。我基本上以相同的方式设置它们,但它不起作用。我敢肯定我一定在某个地方遇到了逻辑问题,但我绞尽脑汁想弄明白。任何帮助将不胜感激。我确定我正在做的事情既小又愚蠢。

double largest=0;
for (int k = 0; k < quarterlyArray.length; k++) { // Determines the largest quarterly rainfall.
  if ( quarterlyArray[k] >= largest ) {
    largest = quarterlyArray[k];
  }
}

for (int k = 0; k < quarterlyArray.length; k++) { // Determines in which quarter had largest rainfall.
  if (quarterlyArray[k] == largest) {
    System.out.println("Quarter " + (k+1) + " saw the most rain this year with " + largest + " inches.");
  }
}

double smallest = 0;  
for (int p = (quarterlyArray.length-1); p == 0; p--) { // This is not working right now. 
  if (quarterlyArray[p] < quarterlyArray [quarterlyArray.length-1] ||  quarterlyArray[p] < smallest) {
    quarterlyArray[p] = smallest;
  }
}

for (int l = quarterlyArray.length; l == 0; l--) { // Nor this.
  if (quarterlyArray[l] == smallest) {
    System.out.println("Quarter " + (l+1) + " saw the least rain this year with " + smallest + " inches.");
  }
}

最佳答案

我注意到的一些事情导致了您的问题:

for (int p = (quarterlyArray.length-1); p == 0; p--) {

p == 0termination expression .你的循环只会在这个条件为 true 时迭代.您的循环将不会执行,因为条件是 false在第一次迭代中。

for (int l = quarterlyArray.length; l == 0; l--) {

这个循环也有同样的问题。在您的第一个 for 循环中查看您的情况 - k < quarterlyArray.length .当这是 false ,你的循环将终止。

quarterlyArray[p] = smallest

您修改的是数组而不是局部变量 smallest .

您还需要注意数组的边界。你的循环集 l到数组长度 - int l = quarterlyArray.length .如果您随后尝试使用 quarterlyArray[l] 对该数组进行索引你会得到一个 ArrayIndexOutOfBoundsException因为 Java 数组(以及我会说的大多数编程语言)是 0-based .

要指出的另一件事是您如何计算 minmax .比如说,你的 quarterlyArray包含所有负值。什么会 largest是?好吧,数组中的所有项都不大于 0 , 所以 largest将为 0。那是不正确的,因为该值不在数组中。

在您的第一种情况下,看起来您从一个元素开始,您知道该元素总是低于数组中的元素。如果您知道所有元素都将大于该值,则效果很好。你的double largest = 0将根据您正在解决的问题的约束更改为数组的最大值。

解决此问题的更好方法是从数组中的已知元素 开始。如果你只是改变你的 largest成为数组中的第一个/最后一个元素,然后遍历其余元素,你总会得到想要的结果。

double largest = quarterlyArray[0];
for (int k = 1; k < quarterlyArray.length; k++) { // Determines the largest quarterly rainfall.
  if ( quarterlyArray[k] >= largest ) {
    largest = quarterlyArray[k];
  }
}

注意我是如何改变的是largest的初始化, 和 int k = 1 .您可以为 smallest 做同样的事情.在这种情况下,我从数组的末尾开始。

double smallest = quarterlyArray[quarterlyArray.length - 1];  
for (int p = quarterlyArray.length - 2; p >= 0; p--) {right now. 
  if (quarterlyArray[p] < smallest) {
    smallest = quarterlyArray[p];
  }
}

完成此操作后的另一个注意事项是,如何在 1 for 中同时做到这两点?循环?

关于java - 尝试确定 Java 数组中的最小数量和位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33398085/

相关文章:

java - Android GridLayout 中的不同高度

java - 无法登录 Kerberos 背后的 Jenkins

java - 如何阻止 Jackson JSON 映射器隐式转换为字符串?

java - 集合的通用返回类型

java - 使用 @XmlJavaTypeAdapter 映射 Map 时的 JAXB 和空命名空间

java - 静态方法作为独立类更慢?

java - java中查找字符串中的重复项

Java Swing 编译的应用程序不显示

java - 实现通用抽象 jaxrs 服务

java - 如何为 json 对象列表设置父级