在2D阵列中表示标记的更简单方法



我是编程新手,我创建了一个简单的井字游戏。它接受了一个2d数组的行和列的输入。然而,我想让它更简单,并使用值1-9来表示板上的每个正方形。

我做这件事的方式似乎相当漫长和复杂。很抱歉格式不正确,因为我想节省空间。

if (pos >= 0 && pos <= 9) { //checks if number is a valid position on the board
if (pos == 1 && board[0][0] == ' ') { board[0][0] = xo; return true; }
if (pos == 2 && board[0][1] == ' ') { board[0][1] = xo; return true; }
if (pos == 3 && board[0][2] == ' ') { board[0][2] = xo; return true; }
if (pos == 4 && board[1][0] == ' ') { board[1][0] = xo; return true; }
if (pos == 5 && board[1][1] == ' ') { board[1][1] = xo; return true; }
if (pos == 6 && board[1][2] == ' ') { board[1][2] = xo; return true; }
if (pos == 7 && board[2][0] == ' ') { board[2][0] = xo; return true; }
if (pos == 8 && board[2][1] == ' ') { board[2][1] = xo; return true; }
if (pos == 9 && board[2][2] == ' ') { board[2][2] = xo; return true; }
}
return false;

内部if语句检查索引是否为空,然后根据输入的数字指定xo。如果有人知道任何"更干净"、更简单的方法,我们将不胜感激。

分配、算术和一元运算符

  • /-除法运算符
  • %-余数运算符

只使用19:范围内的一个变量pos,就可以获得单元[i][j]的坐标,而根本不需要循环

public static boolean isValid(int pos, char xo) {
int i = (pos - 1) / 3; // row
int j = (pos - 1) % 3; // column
if (board[i][j] == ' ') {
board[i][j] = xo;
return true;
}
return false;
}

使用数组做这些事情要方便得多。我会这样做:

int p = 1;
for (int i = 0; i < 3; i++) {
for (int j = 0; i < 3; i++) {
if (p == pos && board[i][j] == ' ') {
board[i][j] = xo;
return true;
p += 1;
}
}
}
return false;
int count = 1; //value of pos
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) {
char ch = board[i][j]; //setting that board value to ch
if (pos == count && ch == ' ') {
board[i][j] = xo; //that board value becomes xo
return true; //returns true
}
count++;
}
}
return false;

最新更新