多维数组怎么学?看这一篇就够了,带你在游戏中学习。
程序员文章站
2022-06-05 19:47:17
...
tic-tac-toe 游戏 (井字棋游戏)
大家小时候应该都玩过井字棋吧,下课之余和同学来上一把,是多么开心。今天 Aaron 就带你来学会用程序来判断井字棋胜利的一方。
- 读入一个 3X3 的矩阵,矩阵中的数字为 1 表示该位置上有一个 X,为 0 表示 O
- 程序判断这个矩阵中是否有获胜的一方,输出表示获胜一方的字符 X
大家可以直接看程序,我作了详细的注释。
// 二维数组
Scanner in = new Scanner(System.in);
final int SIZE = 3;
int[][] board = new int[SIZE][SIZE];
boolean gotResult = false;
int numOFX = 0;
int numOFO = 0;
// 输入矩阵
for(int i = 0; i< board.length; i ++)
{
for(int j = 0; j < board[i].length; j++)
{
board[i][j] = in.nextInt();
}
}
// 检查行
for(int i = 0; i< board.length; i++)
{
numOFX = 0;
numOFO = 0;
for(int j = 0; j< board[i].length;j ++)
{
if (board[i][j] ==1)
{
numOFX ++;
}
else
{
numOFO ++;
}
}
if(numOFX == SIZE || numOFO == SIZE)
{
gotResult = true;
break;
}
}
// 检查列
if ( !gotResult)
{
numOFX = 0;
numOFO = 0;
for(int i = 0; i< board.length; i++)
{
for(int j = 0; j< board[i].length;j ++)
{
if (board[j][i] ==1)
{
numOFX ++;
}
else
{
numOFO ++;
}
}
if(numOFX == SIZE || numOFO == SIZE)
{
gotResult = true;
break;
}
}
}
// 判断反对角线
if ( !gotResult)
{
numOFX = 0;
numOFO = 0;
for(int i1 = 0; i1< board.length; i1++)
{
if( board[i1][SIZE-i1-1] ==1)
{
numOFX ++;
}
else
{
numOFO ++;
}
if(numOFX == SIZE || numOFO == SIZE)
{
gotResult = true;
break;
}
}
}
// 判断对角线
if ( !gotResult)
{
numOFX = 0;
numOFO = 0;
for(int i1 = 0; i1< board.length; i1++)
{
if( board[i1][i1] ==1)
{
numOFX ++;
}
else
{
numOFO ++;
}
if(numOFX == SIZE || numOFO == SIZE)
{
gotResult = true;
break;
}
}
}
if(gotResult )
{
if(numOFX == SIZE)
{
System.out.println("X 赢了");
}
else
{
System.out.println("O 赢了");
}
}
if(!gotResult)
{
System.out.println("没有结果");
}
代码总的来说就是是个四个循环,先判断行是否出现三个相同元素,在判断列,最后判断两个对角线。简单易懂,希望对你有帮助!
System.out.println("给我个喜欢!");