我是该站点的新手,并且是编程的新手,所以请保持谦虚。我正在做一个作业,我已经完成了它所需要的一切,但是我在一个特定的部分上遇到了问题。
因此,下面的代码只是我遇到问题的整个程序的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
是终止表达。仅当此条件为时,您的循环才会迭代true
。您的循环将不会执行,因为条件false
在第一次迭代中。
for (int l = quarterlyArray.length; l == 0; l--) {
这个循环中也有同样的问题。在第一个循环中查看您的状况k < quarterlyArray.length
。如果为false
,则您的循环将终止。
quarterlyArray[p] = smallest
您正在修改数组,而不是局部变量smallest
。
您还需要注意数组的边界。您的循环设置l
为数组长度- int l = quarterlyArray.length
。如果您随后尝试使用索引到该数组quarterlyArray[l]
,则会得到一个ArrayIndexOutOfBoundsException
原因,因为Java数组(以及我会说的大多数编程语言)都是基于0的。
需要指出的另一件事是您如何计算min
和max
。例如,假设您quarterlyArray
包含所有负值。那会largest
是什么?好吧,数组中的所有项目都不大于0
,因此largest
将为0。这将是不正确的,因为该值不在数组中。
在第一种情况下,您似乎是从一个元素开始的,而该元素将永远比array中的元素低。如果您知道所有元素都将大于此范围,则此方法很好。您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
循环中同时进行这两个操作?
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句