如何解决在二维数组中表示索引的更简单方法
我是编程新手,我已经创建了一个简单的井字游戏。它接受了二维数组的行和列的输入。但是,我想让它更简单,并使用 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 语句检查索引是否为空,然后根据输入的数字分配 x
或 o
。如果有人知道这样做的任何“更清洁”和更简单的方法,将不胜感激。
解决方法
Assignment,Arithmetic,and Unary Operators
-
/
- 除法运算符 -
%
- 余数运算符
只需使用一个变量[i][j]
,范围从pos
到1
,您就可以得到单元格9
的坐标,完全不需要循环:
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;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。