我遇到了增加4个嵌套while循环的问题。假设您有一个double类型的数组,以及许多用于递增循环的整数。这是一个例子
private static double[] approxOfU(double w, double x, double y, double z,
double u) {
double a = 0, b = 0, c = 0, d = 0;
final double[] powerArray = { -5.0, -4.0, -3.0, -2.0, -1, (-1.0 / 2.0),
(-1.0 / 3.0), (-1.0 / 4.0), 0, (1.0 / 4.0), (1.0 / 3.0),
(1.0 / 2.0), 1, 2, 3, 4, 5 };
double[] temp = new double[5];
double approx;
int i = 0, j = 0, k = 0, l = 0;
while (i < powerArray.length) {
a = powerArray[i];
while (j < powerArray.length) {
b = powerArray[j];
while (k < powerArray.length) {
c = powerArray[k];
while (l < powerArray.length) {
d = powerArray[l];
approx = Math.pow(w, a) * Math.pow(x, b)
* Math.pow(y, c) * Math.pow(z, d);
if (Math.abs(approx - u) / u <= 0.01) {
temp[0] = a;
temp[1] = b;
temp[2] = c;
temp[3] = d;
temp[4] = approx;
}
l++;
}
k++;
}
j++;
}
i++;
}
return temp;
}
我在哪里添加i ++,j ++,k ++和l ++等增量?赋值只需要在项目的这一部分使用while循环。我已经开始工作的项目的for循环部分。请让我知道你的想法。这段代码不是赋值的真正代码,但我想了解如何更新这些嵌套循环的逻辑,并能够从中获取正确的数据。当我使用下面的变量输出到屏幕时,我最终得到0,所以有些事情是不对的。通常我将增量1(i ++,j ++,...等)放在大括号的大括号末尾。在这种情况下,该方法不会产生良好的结果。请帮忙! :)
答案 0 :(得分:1)
如果你没有对索引做任何魔术,并且只需要循环中的数组元素(而不是索引),那么你可以使用增强的for循环:
double[] updateArray = new double[7];
/* fill your array */
for(double i : updateArray) {
for(double w : updateArray) {
for(double y : updateArray) {
for(double x : updateArray) {
// No incrementing or indices required :)
}
}
}
}
答案 1 :(得分:0)
与for循环相同,在循环结束时执行增量。
double[] updateArray = new double[7];
double w,x,y,z;
int i=0, j=0, k=0, l=0;
while(i < updateArray.length)
{
w = updateArray[i];
while(j < updateArray.length)
{
x = updateArray[j];
while(k < updateArray.length)
{
y = updateArray[k];
while(l < updateArray.length)
{
z = updateArray[l];
l ++;
}
k ++;
}
j ++;
}
i ++;
}
答案 2 :(得分:0)
你可以这样做。
double[] updateArray = new double[7];
double w,x,y,z;
int i=0, j=0, k=0, l=0;
while(i++ < updateArray.length -1)
{
w = updateArray[i];
while(j++ < updateArray.length -1)
{
x = updateArray[j];
while(k++ < updateArray.length -1)
{
y = updateArray[k];
while(l++ < updateArray.length -1)
{
z = updateArray[l];
}
}
}
}