我正在尝试比较同一数组的元素。这意味着我想将 0 元素与其他所有元素进行比较,将 1 元素与其他所有元素进行比较,依此类推。问题是它没有按预期工作。 。我所做的是我有两个从 0 到 array.length-1 的 for 循环。然后我有一个 if 语句,如下所示: if(a[i]!=a[j+1])
for (int i = 0; i < a.length - 1; i++) {
for (int k = 0; k < a.length - 1; k++) {
if (a[i] != a[k + 1]) {
System.out.println(a[i] + " not the same with " + a[k + 1] + "\n");
}
}
}
首先,您需要循环到< a.length
而不是a.length - 1
。因为这严格小于您需要包含的上限。
因此,要检查所有元素对,您可以执行以下操作:
for (int i = 0; i < a.length; i++) {
for (int k = 0; k < a.length; k++) {
if (a[i] != a[k]) {
//do stuff
}
}
}
但这会比较,例如a[2]
to a[3]
进而a[3]
to a[2]
。鉴于您正在检查!=
这似乎很浪费。
更好的方法是比较每个元素i
to the 数组的其余部分:
for (int i = 0; i < a.length; i++) {
for (int k = i + 1; k < a.length; k++) {
if (a[i] != a[k]) {
//do stuff
}
}
}
所以如果你有索引 [1...5] 比较就会进行
-
1 -> 2
-
1 -> 3
-
1 -> 4
-
1 -> 5
-
2 -> 3
-
2 -> 4
-
2 -> 5
-
3 -> 4
3 -> 5
4 -> 5
所以你会看到配对没有重复。想象一圈人都需要互相握手。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)