我有一个有逻辑的方法
首先,它看起来像是:
static boolean checkWin(char dot) {
if (map[0][0] == dot && map[0][1] == dot && map[0][2] == dot) {
return true;
}
//more code
if (map[0][2] == dot && map[1][1] == dot && map[2][0] == dot) {
return true;
}
return false;
}
通过循环,我重构了方法:
static boolean checkWin(char dot) {
for (int i = 0; i <map.length ; i++) {
for (int j = 0; j < map[i].length; j++) {
if (map[0][i] == dot && i == 2) {
return true;
}
if (map[1][i] == dot && i == 2) {
return true;
}
if (map[2][i] == dot && i == 2) {
return true;
}
if (map[i][0] == dot && i == 2) {
return true;
}
if (map[i][1] == dot && i == 2) {
return true;
}
if (map[i][2] == dot && i == 2) {
return true;
}
if (map[i][i] == dot && i == 2) {
return true;
}
if (map[0][2] == dot && map[1][1] == dot && map[2][0] == dot) {
return true;
}
}
}
return false;
}
我对这一行代码有一个问题:
if (map[0][2] == dot && map[1][1] == dot && map[2][0] == dot)
return true;
}
我需要得到map[i][?]
,当i
分别为0、1和2时,?
应该假定值为2、1和0。
我怎样才能做到这一点?
发布于 2022-04-04 10:03:24
尽量减少
for (int i = 2; i > = 0; i--) {
}
我将成为2 1 0
P.S我想你错过了2
P.S如果我正确理解您的问题,您需要在不修改for
本身的情况下让2 1 0
在循环中运行?在这种情况下,请尝试:
for (int i = 3; i < 3; i++) {
... 2 - i
}
https://stackoverflow.com/questions/71735325
复制相似问题