我正在尝试阅读下面的数组。我想要做的只是验证数字1和2是否同时存在于数组中。问题出在我的方法上。我继续得到“使用未分配的局部变量'jogavel1'”,这是在我的方法中。有人可以帮助或解释我做错了什么吗?非常感谢您的参与=)。
int[,] tabuleiro = new int[8, 8] {
{1, 0, 1, 0, 1, 0, 1, 0},
{0, 1, 0, 1, 0, 1, 0, 1},
{1, 0, 1, 0, 1, 0, 1, 0},
{0, 0, 0, 0, 0, 0, 0, 0},
{0, 0, 0, 0, 0, 0, 0, 0},
{0, 2, 0, 2, 0, 2, 0, 2},
{2, 0, 2, 0, 2, 0, 2, 0},
{0, 2, 0, 2, 0, 2, 0, 2},
};
int numero = verificar(tabuleiro);
Console.ReadKey();
}
public static int verificar(int[,] tabuleiro) {
int jogavel, jogavel1, jogavel2 = 0;
for (int i = 0; i < 7; i++) {
for (int a = 0; a < 7; a++) {
if (tabuleiro[i, a] == 1) {
jogavel1++;
}
else if (tabuleiro[i, a] == 2) {
jogavel2++;
}
}
}
if (jogavel1 > 0 && jogavel2 > 0) {
jogavel = 1;
}
else
jogavel = 0;
return jogavel;
}
}
答案 0 :(得分:2)
您的变量实例化是问题所在:
int jogavel, jogavel1, jogavel2 = 0;
这样做只会为jogavel2
分配一个值。
相反,你应该像这样分配它们:
int jogavel; // in your case this variable doesn't necessarily needs to be assigned
int jogavel1 = 0;
int jogavel2 = 0;
说明:
在for-loop中,您使用jogavel1
和jogavel2
并使用++
- 运算符递增它们。对于未分配的变量,这是不可能的,这适用于jogavel1
。另一方面,jogavel
并不一定需要分配值,因为您不能将其用于直接计算。相反,您只需在if-else语句中为其分配一个值,这对编译器来说很好。
顺便说一句,你的逻辑出现错误:在你的循环中,你不能从数组中获取最后的元素。您使用i < 7
resp。 a < 7
作为中断条件,这是不正确的,因为您的锯齿状数组在每个维度中有8个元素。所以你最好这样编辑:
...
for (int i = 0; i < tabuleiro.GetLength(0); i++) // array-length of 1. dimension (=8)
{
for (int a = 0; a < tabuleiro.GetLength(1); a++) // len. of 2. dimension (=8)
...
答案 1 :(得分:0)
未初始化局部变量。您必须手动初始化它们。
所以你的代码应该是
int jogavel, jogavel1=0, jogavel2 = 0;