Tec Tac Toc不会更新电路板上的动作

时间:2013-10-28 11:24:52

标签: java tic-tac-toe

我正试图从我的书中制作“Tec Tac Toc”游戏。

问题在于我没有让玩家在棋盘上移动更新。我只让计算机移动。

我该怎么做才能解决问题?

我试图让代码尽可能清晰。

我写的代码:

import java.util.Scanner;

public class TecTacToe {


  Scanner input=new Scanner(System.in);  





  private char[][] squares ;

DDD

  public  TecTacToe() {



 squares=new char[][]{{'.' , '.', '.'},
                      {'.' , '.', '.'}  ,      
                      {'.' , '.', '.'}};



  }   

DD

  public String toString(){
  String result="";
   for(int row=0;row<3;row++){
           for(int column=0;column<3;column++){
               result+=squares[row][column];



           }
           result+="\n";
      }
  return result;

  }

FFF

       public static void main(String[] args) {


        TecTacToe game= new TecTacToe();
         System.out.println("welcome to Tic Tac Toe");
         game.play();
          System.out.println(game);
           System.out.println("Game over");





}

dd

public boolean gameOver(){
  if(score()!=0){
  return true;

  }

   for(int row=0;row<3;row++){
      for(int column=0;column<3;column++){

         if(squares[row][column]=='.'){

          return false;
         } //end of if statment
      }//second loop
   }// first loop
   return true;
      }// end of game over class

FF

public int score(){

  int lineScore;

  for(int i=0;i<3;i++){

  lineScore=scoreLine(squares[i][0],squares[i][1],squares[i][2]);

  if(lineScore!=0){
      return lineScore;
  }

  lineScore=scoreLine(squares[0][i],squares[1][i],squares[2][i]);

   if(lineScore!=0){
      return lineScore;
  }
     }

    lineScore=scoreLine(squares[0][0],squares[1][1],squares[2][2]);

   if(lineScore!=0){
      return lineScore;
  }


   return scoreLine(squares[0][2],squares[1][1],squares[2][0]);



  }

DDD

 protected int scoreLine(char a,char b, char c){

  if( (a=='X') && (b=='X')&& (c=='X')){ return 1;}

    if((a=='O')&&(b=='O')&&(c=='O')) {return -1;}

  return 0;
  }

DDD

  public void play(){

char player ='X';
for(int move=0;move<9;move++){
if(gameOver()){
return;

}
if(player=='X'){
playbestMove();
player='0';
}
else{
    System.out.println(this);
    System.out.println("Enter the row: ");
 int row=input.nextInt();
    System.out.println("Enter the column: ");
 int column=input.nextInt();      

    squares[row][column]='0';
    player='X';
}


}


}

DDD

 protected void playbestMove(){

  int score;
  int bestScore=-2;
  int bestRow=-1;
  int bestColumn=-1;

  for(int row=0;row<3;row++){
  for(int column=0;column<3;column++){
     if(squares[row][column]=='.'){
     squares[row][column]='X';
     score=score();
     bestRow=row;
     bestColumn=column;
     }
     squares[row][column]='.';
  }
  }


  squares[bestRow][bestColumn]='X';
  }

DDD

  }//end of tec tac toe class

1 个答案:

答案 0 :(得分:1)

您的代码中有多个错误。

    playBestMove()中的
  • squares[row][column] = '.'应该进入if语句,否则会删除之前的所有动作。

  • play()中,您为人类玩家使用角色0(零),但在得分线中,您会检查O(元音)

此外,您的playBestMove算法只是将十字架放在最后一个可用位置,而不是最佳移动。