我是这个网站的新手,一般来说也是编程新手,所以请保持温和。我正在做一项任务,我已经构建了它需要的一切,但我在一个特定部分遇到了问题。
所以下面的代码只是我遇到问题的整个程序的 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 == 0
是termination 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 .
要指出的另一件事是您如何计算 min
和 max
.比如说,你的 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/