布尔赋值不抓,需要了解更多


public class MyClass {
public static void main(String args[]) {
int[] nums = {1, 2, 9, 3, 4};
boolean results = false;
int end = nums.length;
if (end>4)end=4;
for (int x=0;x<end;x++)
{
System.out.println(nums[x]);
results = (nums[x] == 9);
}
System.out.println(results);
}
}

以下代码检查数组的前 4 个元素中是否存在 9,但如果数组的前 4 个元素中不超过 1 个"9",则以这种方式使用布尔运算符似乎总是失败。

这是为什么呢?从逻辑上讲,这似乎应该有效,当我理解为什么某些东西不起作用时,它确实有助于我更好地理解。

原因是你已经迭代了所有元素,结果将是最后一个元素的结果,

所以当你找到比赛结果时,你需要停止for

for (int x=0;x<end;x++)
{
System.out.println(nums[x]);
if(nums[x] == 9){
result = true;
break;
}
}

每次都覆盖results。如前所述,这将告诉您数组中的最后一项是否等于 9(它不等于(,而不是数组中的任何项是否等于 9。

如果num[x] == 9,则应将true分配给result;否则,不要分配任何内容。

@lucumt的回答展示了如何做到这一点的一个例子。另一个例子,只需替换

results = (nums[x] == 9);

results |= (nums[x] == 9);

其中|=赋值等效于results = results || (num[x] == 9);- 换句话说,如果任何值为 true,则整个表达式将为 true。(请注意,@lucumt 的答案效率稍高一些,因为它是 O(n(,而这是 Theta(n( - 即这将始终运行n次,其中n是列表的长度,但如果找到任何 9 @lucumt,它可以提前结束循环(。

在你的 for 循环中,你每次都过度写入值。这意味着您正在测试第 4 个值是否等于 9。

您可以像这样解决问题:

boolean results = false;
for (int x = 0; x < end; x++) {
System.out.println(nums[x]);
if(nums[x] == 9) {
results = true;
break;
}
}

试试这个:

boolean isPresent(int[] nums, int val)
{
for (int x : nums )
{
if (nums[x] == val)
return true;
}
return false;
}

否则,每次检查时都会重写一个值

我给你写了一个类。如果给定数组在前 4 个元素中的一个或多个元素中包含 9,则方法 nignPresentInFirst4Elements(int[] arr( 返回 true:

public class Test {
private static boolean nignPresentInFirst4Elements(int[] arr) {
if(arr == null)
return false;
for(int i = 0; i < Math.min(arr.length, 4); i++) {
if(arr[i] == 9)
return true;
}
return false;
}
public static void main(String[] args) {
int[][] arrs = new int[][] {
{5, 8, 9, 3},
{5, 8, 9, 3, 8, 26},
{5, 8, 9, 9},
{5, 8, 23, 0}
};
for(int i = 0; i < arrs.length; i++) {
System.out.println(toString(arrs[i]) + " | " + nignPresentInFirst4Elements(arrs[i]));
}
}
private static String toString(int[] arr) {
if(arr == null)
return "null";
String s  = "[";
if(arr.length > 0)
s += arr[0];
for(int i = 1; i < arr.length; i++) {
s += ", " + arr[i];
}
s += "]";
return s;
}
}

相关内容

  • 没有找到相关文章

最新更新