Java实现五子棋游戏(控制台版)

 更新时间:2021年10月10日 09:44:03   作者:是语呀-  
这篇文章主要为大家详细介绍了Java控制台版实现五子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本项目为大家分享了Java实现五子棋游戏的具体代码,供大家参考,具体内容如下

该项目为Java编程语言编写的五子棋游戏(控制台版),用到二维数组、for循环、if语句、while()语句、Scanner Until包,此项目主要是对数组的使用。该项目的功能有落子、输出棋盘、判断输赢。

代码条:

package edu.qizi.gam;
 
import java.util.Scanner;
 
public class GobangTest {
 public static void main(String[] args) {
  int BoardSize = 20;
  // 棋盘的实现
  String[][] board = new String[BoardSize][BoardSize];
  
  for (int i = 0; i < board.length; i++) {
   for (int j = 0; j < board[i].length; j++) {
    board[i][j] = "+";
   }
  }
  //输出棋盘
  PrintBoard(board);
  while(true) {
  //黑棋落子
  System.out.println("黑棋落子");
  BlackMoveLater(board);
//  每下一步黑棋要输出一下棋盘
  PrintBoard(board);
  
//  行判断黑棋
  BlackRow(BoardSize, board);
//  列判断黑棋
  BlackLine(BoardSize, board);
//  自左上--->右下判断黑棋,每次第二个for循环最开始列不变,阶梯逼近左下的方法
  BlackTopLeftToBottomRight_Line(BoardSize, board);
//  自左上--->右下判断黑棋,每次第二个for循环最开始行不变,阶梯逼近右上的方法
  BlackTopLeftToBottomRight_Row(BoardSize, board);
//  自右上--->左下判断黑棋,每次第二个for循环最开始列不变,阶梯逼近右下的方法
  BlackTopRightToBottomLeft_Line(BoardSize, board);
//  自右上--->左下判断黑棋,每次第二个for循环最开始行不变,阶梯逼近左上的方法
  BlackTopRightToBottomLeft_Row(BoardSize, board);
  
  
//  白棋落子
  System.out.println("白棋落子");
  WhiteMoveLater(board);
//  每下一步白棋要输出一下棋盘
  PrintBoard(board);
  
//  行判断白棋
  WhiteRow(BoardSize, board);
//  列判断白棋
  WhiteLine(BoardSize, board);
//  自左上--->右下判断白棋,每次第二个for循环最开始列不变,阶梯逼近左下的方法
  WhiteTopLeftToBottomRight_Line(BoardSize, board);
//  自左上--->右下判断白棋,每次第二个for循环最开始行不变,阶梯逼近右上的方法
  WhiteTopLeftToBottomRight_Row(BoardSize, board);
//  自右上--->左下判断白棋,每次第二个for循环最开始列不变,阶梯逼近右下的方法
  WhiteTopRightToBottomLeft_Line(BoardSize, board);
//  自右上--->左下判断白棋,每次第二个for循环最开始行不变,阶梯逼近左上的方法
  WhiteTopRightToBottomLeft_Row(BoardSize, board);
  } 
 }

下面是实现的方法

//实现棋盘输出的方法
 public static void PrintBoard(String[][] board) {
   for (int i = 0; i < board.length; i++) {
    for (int j = 0; j < board[i].length; j++) {
     System.out.print( board[i][j]+" ");
    }
    System.out.println();
   }
  }

实现黑棋落子

// 实现黑棋落子的方法
 public static void BlackMoveLater(String[][] board) {
  while(true) {
  Scanner sc1=new Scanner(System.in);
  System.out.println("请输入黑棋落子的横坐标[1---20]:");
  int BlackBoard_x=sc1.nextInt();
  //判断横坐标是否数组越界
  if(BlackBoard_x<1 || BlackBoard_x>20) {
   System.out.println("你输入的坐标范围有误 ,横坐标取1到20,请正确输入:\n");
   continue;
  }
  Scanner sc2=new Scanner(System.in);
  System.out.println("请输入黑棋落子的纵坐标[1---20]:");
  int BlackBoard_y=sc2.nextInt();
  //判断纵坐标是否数组越界
  if(BlackBoard_y<1 || BlackBoard_y>20) {
   System.out.println("你输入的坐标范围有误,纵坐标取1到20,请正确输入:\n");
   continue;
  }
  //判断此位置是否可以落入棋子
  if(board[BlackBoard_x-1][BlackBoard_y-1]=="○") {
   System.out.println("此位置已经有棋子了,请你将棋子下到空位置");
   continue;
  }else {
    board[BlackBoard_x-1][BlackBoard_y-1]="●";
    break;
  }
  }
 }

实现白棋落子

// 实现白棋落子的方法
 public static void WhiteMoveLater(String[][] board) {
  while(true) {
  Scanner sc1=new Scanner(System.in);
  System.out.println("请输入白棋落子的横坐标[1---20]:");
  int WhiteBoard_x=sc1.nextInt();
  //判断横坐标是否数组越界
  if(WhiteBoard_x<1 || WhiteBoard_x>20) {
   System.out.println("你输入的坐标范围有误 ,横坐标取1到20,请正确输入:\n");
   continue;
   }
  Scanner sc2=new Scanner(System.in);
  System.out.println("请输入白棋落子的纵坐标[1---20]:");
  int WhiteBoard_y=sc2.nextInt();
  //判断纵坐标是否数组越界
  if(WhiteBoard_y<1 || WhiteBoard_y>20) {
   System.out.println("你输入的坐标范围有误,纵坐标取1到20,请正确输入:\n");
   continue;
   }
  //判断此位置是否可以落入棋子
  if(board[WhiteBoard_x-1][WhiteBoard_y-1]=="●") {
   System.out.println("此位置已经有棋子了,请你将棋子下到空位置\n");
   continue;
  }else {
   board[WhiteBoard_x-1][WhiteBoard_y-1]="○";
   break;
  }
  }
 }

判定输赢以黑棋为例(有六个方法),下面一一列举

// 实现行判断黑棋子
 public static void BlackRow(int BoardSize, String[][] board) {
//  先定义一个数number,以此来计数
  int number=0;
//  一行一行的读取数组中的元素
  for(int row=0;row<BoardSize;row++) {
   for(int line=0;line<BoardSize;line++) {
//    如果此行中有元素为黑棋则number+1
    if(board[row][line]=="●") {
     number++;
    }
//    当number为5的时候则黑棋一方的胜
    while(number==5) {
     System.out.println("黑棋方胜!");
        //胜出后输出棋盘
        for ( row = 0; row < board.length; row++) {
         for ( line = 0; line < board[row].length; line++) {
          System.out.print( board[row][line]+" ");
         }
         System.out.println();
        }
        //胜后退出系统
        System.exit(0);
    }
//    如果此行中虽有五个黑棋但是并不相连,不能说是黑棋方胜,需将number置为0
    if(board[row][line]=="○"|| board[row][line]=="+") {
     number=0;
    }
   }
//   每一行读取数组元素后未能分出胜负需要将number置为0
   number=0;
  }
 }

展现第一个方法的结果

第二个方法代码

// 实现列判断黑棋子
 public static void BlackLine(int BoardSize, String[][] board) {
//  先定义一个数number,以此来计数
  int number=0;
//  一列一列的读取数组中的元素
  for(int Line=0;Line<BoardSize;Line++) {
   for(int row=0;row<BoardSize;row++) {
//    如果此列中有元素为黑棋则number+1
    if(board[row][Line]=="●") {
     number++;
    }
//    当number为5的时候则黑棋一方的胜
    while(number==5) {
     System.out.println("黑棋方胜!");
        //胜出后输出棋盘
        for ( row = 0; row < board.length; row++) {
         for ( Line = 0; Line < board[row].length; Line++) {
          System.out.print( board[row][Line]+" ");
         }
         System.out.println();
        }
        //胜后退出系统
        System.exit(0);
    }
//    如果此列中虽有五个黑棋但是并不相连,不能说是黑棋方胜,需将number置为0
    if(board[row][Line]=="○"|| board[row][Line]=="+") {
     number=0;
    }
   }
//   每一列读取数组元素后未能分出胜负需要将number置为0
   number=0;
  }
 }

展现第二个方法的结果

 

第三个方法代码

// 实现自左上--->右下判断黑棋,每次第二个for循环最开始列不变,阶梯逼近左下的方法
 public static void BlackTopLeftToBottomRight_Line(int BoardSize, String[][] board) {
//  先定义一个数number,以此来计数
  int number=0;
//  每当执行第二个for循环的时候列line总是从0开始
  for(int row=0;row<BoardSize;row++) {
//   执行这个for循环的时候每一次行+1,列+1,数据元素呈现阶梯分布,阶梯逼近左下
   for(int line=0,i=row;line<BoardSize-row;line++,i++) {
//    如果此阶梯中有元素为黑棋则number+1
    if(board[i][line]=="●") {
     number++;
    }
//    当number为5的时候则黑棋一方的胜
    while(number==5) {
     System.out.println("黑棋方胜!");
        //胜出后输出棋盘
        for ( row = 0; row < board.length; row++) {
         for ( line = 0; line < board[i].length; line++) {
          System.out.print( board[row][line]+" ");
         }
         System.out.println();
        }
        //胜后退出系统
        System.exit(0);
    }
//    如果此阶梯中虽有五个黑棋但是并不相连,不能说是黑方胜,需将number置为0
    if(board[i][line]=="○"|| board[i][line]=="+") {
     number=0;
    }
   }
//   每当第二个for循环完毕后需要将number置为0
   number=0;
  }
 }

展现第三种方法的结果

第四个方法代码

// 实现自左上--->右下判断黑棋,每次第二个for循环最开始行不变,阶梯逼近右上的方法
 public static void BlackTopLeftToBottomRight_Row(int BoardSize, String[][] board) {
//  先定义一个数number,以此来计数
  int number=0;
//  每当执行第二个for循环的时候行row总是从0开始
  for(int line=0;line<BoardSize;line++) {
//   执行这个for循环的时候每一次列+1,行+1,数据元素呈现阶梯分布,阶梯逼近右上
   for(int row=0,i=line;row<BoardSize-line;row++,i++) {
//    如果此阶梯中有元素为黑棋则number+1
    if(board[row][i]=="●") {
     number++;
    }
//    当number为5的时候则黑棋一方的胜
    while(number==5) {
     System.out.println("黑棋方胜!");
        //胜出后输出棋盘
        for ( row = 0; row < board.length; row++) {
         for ( line = 0; line < board[row].length; line++) {
          System.out.print( board[row][line]+" ");
         }
         System.out.println();
        }
        //胜后退出系统
        System.exit(0);
    }
//    如果此阶梯中虽有五个黑棋但是并不相连,不能说是黑方胜,需将number置为0
    if(board[row][i]=="○"|| board[row][i]=="+") {
     number=0;
    }
   }
//   每当第二个for循环完毕后需要将number置为0
   number=0;
  }
 }

第四个方法结果展示

第五个方法的代码

// 实现自右上--->左下判断黑棋,每次第二个for循环最开始列不变,阶梯逼近右下的方法
 public static void BlackTopRightToBottomLeft_Line(int BoardSize, String[][] board) {
//  先定义一个数number,以此来计数
  int number=0;
//  每当执行第二个for循环的时候列line总是从最后一列开始
  for(int row=0;row<BoardSize;row++) {
//   执行这个for循环的时候每一次列+1,行+1,数据元素呈现阶梯分布,阶梯逼近右下
   for(int line=BoardSize-1,i=row;line>=0+row;line--,i++) {
//    如果此阶梯中有元素为黑棋则number+1
    if(board[i][line]=="●") {
     number++;
    }
//    当number为5的时候则黑棋一方的胜
    while(number==5) {
     System.out.println("黑棋方胜!");
        //胜出后输出棋盘
        for ( row = 0; row < board.length; row++) {
         for ( line = 0; line < board[row].length; line++) {
          System.out.print( board[row][line]+" ");
         }
         System.out.println();
        }
        //胜后退出系统
        System.exit(0);
    }
//    如果此阶梯中虽有五个黑棋但是并不相连,不能说是黑方胜,需将number置为0
    if(board[i][line]=="○"|| board[i][line]=="+") {
     number=0;
    }
   }
//   每当第二个for循环完毕后需要将number置为0
   number=0;
  }
 }

第五个方法结果展示

第六个方法的代码

// 实现自右上--->左下判断黑棋,每次第二个for循环最开始行不变,阶梯逼近左上的方法
 public static void BlackTopRightToBottomLeft_Row(int BoardSize, String[][] board) {
//  先定义一个数number,以此来计数
  int number=0;
//  每当执行第二个for循环的时候行row总是从最后一列开始
  for(int line=BoardSize-1;line>=0;line--) {
//   执行这个for循环的时候每一次列+1,行+1,数据元素呈现阶梯分布,阶梯逼近左上
   for(int row=0,j=line;row<line;j--,row++) {
//    如果此阶梯中有元素为黑棋则number+1
    if(board[row][j]=="●") {
     number++;
    }
//    当number为5的时候则黑棋一方的胜
    while(number==5) {
     System.out.println("黑棋方胜!");
        //胜出后输出棋盘
        for ( row = 0; row < board.length; row++) {
         for ( line = 0; line < board[row].length; line++) {
          System.out.print( board[row][line]+" ");
         }
         System.out.println();
        }
        //胜后退出系统
        System.exit(0);
    }
//    如果此阶梯中虽有五个黑棋但是并不相连,不能说是黑方胜,需将number置为0
    if(board[row][j]=="○"|| board[row][j]=="+") {
     number=0;
    }
   }
//   每当第二个for循环完毕后需要将number置为0
   number=0;
  }
 }

第六个方法结果展示

后面是白棋的判断方法的代码,与黑棋一样

// 实现行判断白棋
 public static void WhiteRow(int BoardSize, String[][] board) {
//  先定义一个数number,以此来计数
  int number=0;
//  一行一行的读取数组中的元素
  for(int row=0;row<BoardSize;row++) {
   for(int line=0;line<BoardSize;line++) {
//    如果此行中有元素为白棋则number+1
    if(board[row][line]=="○") {
     number++;
    }
//    当number为5的时候则白棋一方的胜
    while(number==5) {
     System.out.println("白棋方胜!");
        //胜出后输出棋盘
        for ( row = 0; row < board.length; row++) {
         for ( line = 0; line < board[row].length; line++) {
          System.out.print( board[row][line]+" ");
         }
         System.out.println();
        }
        //胜后退出系统
        System.exit(0);
    }
//    如果此行中虽有五个白棋但是并不相连,不能说是白棋方胜,需将number置为0
    if(board[row][line]=="●"|| board[row][line]=="+") {
     number=0;
    }
   }
//   每一行读取数组元素后未能分出胜负需要将number置为0
   number=0;
  }
 }
// 实现列判断白棋
 public static void WhiteLine(int BoardSize, String[][] board) {
//  先定义一个数number,以此来计数
  int number=0;
//  一列一列的读取数组中的元素
  for(int line=0;line<BoardSize;line++) {
   for(int row=0;row<BoardSize;row++) {
//    如果此列中有元素为白棋则number+1
    if(board[row][line]=="○") {
     number++;
    }
//    当number为5的时候则白棋一方的胜
    while(number==5) {
     System.out.println("白棋方胜!");
        //胜出后输出棋盘
        for ( row = 0; row < board.length; row++) {
         for ( line = 0; line < board[row].length; line++) {
          System.out.print( board[row][line]+" ");
         }
         System.out.println();
        }
        //胜后退出系统
        System.exit(0);
    }
//    如果此列中虽有五个白棋但是并不相连,不能说是白棋方胜,需将number置为0
    if(board[row][line]=="●"|| board[row][line]=="+") {
     number=0;
    }
   }
//   每一列读取数组元素后未能分出胜负需要将number置为0
   number=0;
  }
 }
// 实现自左上--->右下判断白棋,每次第二个for循环最开始列不变,阶梯逼近左下的方法
 public static void WhiteTopLeftToBottomRight_Line(int BoardSize, String[][] board) {
//  先定义一个数number,以此来计数
  int number=0;
//  每当执行第二个for循环的时候列line总是从0开始
  for(int row=0;row<BoardSize;row++) {
//   执行这个for循环的时候每一次行+1,列+1,数据元素呈现阶梯分布,阶梯逼近左下
   for(int line=0,i=row;line<BoardSize-row;line++,i++) {
//    如果此阶梯中有元素为白棋则number+1
    if(board[i][line]=="○") {
     number++;
    }
//    当number为5的时候则白棋一方的胜
    while(number==5) {
     System.out.println("白棋方胜!");
        //胜出后输出棋盘
        for ( row = 0; row < board.length; row++) {
         for ( line = 0; line < board[i].length; line++) {
          System.out.print( board[row][line]+" ");
         }
         System.out.println();
        }
        //胜后退出系统
        System.exit(0);
    }
//    如果此阶梯中虽有五个白棋但是并不相连,不能说是黑白方胜,需将number置为0
    if(board[i][line]=="●"|| board[i][line]=="+") {
     number=0;
    }
   }
//   每当第二个for循环完毕后需要将number置为0
   number=0;
  }
 }
// 实现自左上--->右下判断白棋,每次第二个for循环最开始行不变,阶梯逼近右上的方法
 public static void WhiteTopLeftToBottomRight_Row(int BoardSize, String[][] board) {
//  先定义一个数number,以此来计数
  int number=0;
//  每当执行第二个for循环的时候行row总是从0开始
  for(int line=0;line<BoardSize;line++) {
//   执行这个for循环的时候每一次列+1,行+1,数据元素呈现阶梯分布,阶梯逼近右上
   for( int row=0,i=line;row<BoardSize-line;row++,i++) {
//    如果此阶梯中有元素为白棋则number+1
    if(board[row][i]=="○") {
     number++;
    }
//    当number为5的时候则白棋一方的胜
    while(number==5) {
     System.out.println("白棋方胜!");
        //胜出后输出棋盘
        for ( row = 0; row < board.length; row++) {
         for ( line = 0; line < board[row].length; line++) {
          System.out.print( board[row][line]+" ");
         }
         System.out.println();
        }
        //胜后退出系统
        System.exit(0);
    }
//    如果此阶梯中虽有五个白棋但是并不相连,不能说是白方胜,需将number置为0
    if(board[row][i]=="●"|| board[row][i]=="+") {
     number=0;
    }
   }
//   每当第二个for循环完毕后需要将number置为0
   number=0;
  }
 }
// 实现自右上--->左下判断白棋,每次第二个for循环最开始列不变,阶梯逼近右下的方法
 public static void WhiteTopRightToBottomLeft_Line(int BoardSize, String[][] board) {
//  先定义一个数number,以此来计数
  int number=0;
//  每当执行第二个for循环的时候列line总是从最后一列开始
  for(int row=0;row<BoardSize;row++) {
//   执行这个for循环的时候每一次列+1,行+1,数据元素呈现阶梯分布,阶梯逼近右下
   for(int line=BoardSize-1,i=row;line>=0+row;line--,i++) {
    if(board[i][line]=="○") {
//     如果此阶梯中有元素为白棋则number+1
     number++;
    }
//    当number为5的时候则白棋一方的胜
    while(number==5) {
     System.out.println("白棋方胜!");
        //胜出后输出棋盘
        for ( row = 0; row < board.length; row++) {
         for ( line = 0; line < board[row].length; line++) {
          System.out.print( board[row][line]+" ");
         }
         System.out.println();
        }
        //胜后退出系统
        System.exit(0);
    }
//    如果此阶梯中虽有五个白棋但是并不相连,不能说是白方胜,需将number置为0
    if(board[i][line]=="●"|| board[i][line]=="+") {
     number=0;
    }
   }
//   每当第二个for循环完毕后需要将number置为0
   number=0;
  }
 }
// 实现自右上--->左下判断白棋,每次第二个for循环最开始行不变,阶梯逼近左上的方法
 public static void WhiteTopRightToBottomLeft_Row(int BoardSize, String[][] board) {
//  先定义一个数number,以此来计数
  int number=0;
//  每当执行第二个for循环的时候行row总是从最后一列开始
  for(int line=BoardSize-1;line>=0;line--) {
//   执行这个for循环的时候每一次列+1,行+1,数据元素呈现阶梯分布,阶梯逼近左上
   for(int row=0,j=line;row<line;j--,row++) {
//    如果此阶梯中有元素为白棋则number+1
    if(board[row][j]=="○") {
     number++;
    }
//    当number为5的时候则白棋一方的胜
    while(number==5) {
     System.out.println("白棋方胜!");
        //胜出后输出棋盘
        for ( row = 0;row < board.length; row++) {
         for ( line = 0;line < board[row].length; line++) {
          System.out.print( board[row][line]+" ");
         }
         System.out.println();
        }
        //胜后退出系统
        System.exit(0);
    }
//    如果此阶梯中虽有五个白棋但是并不相连,不能说是白方胜,需将number置为0
    if(board[row][j]=="●"|| board[row][j]=="+") {
     number=0;
    }
   }
//   每当第二个for循环完毕后需要将number置为0
   number=0;
  }
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Java使用OCR技术识别验证码实现自动化登陆方法

    Java使用OCR技术识别验证码实现自动化登陆方法

    在本篇文章里小编给大家分享的是关于Java 如何使用 OCR 技术识别验证码实现自动化登陆的相关知识点内容,需要的朋友们学习下。
    2019-08-08
  • Java设计模式之原型模式(Prototype模式)介绍

    Java设计模式之原型模式(Prototype模式)介绍

    这篇文章主要介绍了Java设计模式之原型模式(Prototype模式)介绍,本文讲解了如何使用原型模式并给出了代码实例,需要的朋友可以参考下
    2015-03-03
  • Redis高并发场景防止库存数量超卖少卖

    Redis高并发场景防止库存数量超卖少卖

    商品超卖是销售数量超过实际库存的情况,常因库存管理不当引发,传统库存管理在高并发环境下易出错,可通过线程加锁或使用Redis同步库存状态解决,本文就来详细的介绍一下,感兴趣的可以了解一下
    2024-09-09
  • 打造一款代码命名工具的详细教程

    打造一款代码命名工具的详细教程

    这篇文章主要介绍了来,我们一起打造一款代码命名工具,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • 如何把spring boot项目部署到tomcat容器中

    如何把spring boot项目部署到tomcat容器中

    本文给大家分享如何把spring boot项目部署到tomcat容器中,本文给大家介绍的非常详细,需要的朋友参考下
    2017-04-04
  • java的时间类汇总(齐全)

    java的时间类汇总(齐全)

    这篇文章主要介绍了java的时间类汇总(齐全),文章围绕主题展开详细的内容介绍,具有一定的参考价值,感兴趣的小伙伴可以参考一下
    2022-09-09
  • Java执行SQL脚本文件到数据库详解

    Java执行SQL脚本文件到数据库详解

    这篇文章主要为大家详细介绍了Java执行SQL脚本文件到数据库的相关方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • SpringBoot读取resource目录下文件失败的原因及解决方案

    SpringBoot读取resource目录下文件失败的原因及解决方案

    在idea中运行时,有些resource下文件读取工具类能够正常获取读取到文件,但是通过java–jar的方式去运行jar包,此时resource下文件读取工具类读取文件就失效了,本文就给大家介绍一下SpringBoot读取resource目录下文件失败解决方案,需要的朋友可以参考下
    2023-08-08
  • 使用Spring Boot Maven插件的详细方法

    使用Spring Boot Maven插件的详细方法

    这篇文章主要介绍了如何使用Spring Boot Maven插件,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-05-05
  • JVM用寄存器实现程序计数

    JVM用寄存器实现程序计数

    这篇文章主要介绍了JVM用寄存器实现程序计数,JVM中的程序计数寄存器(Program Counter Register),Register的命名源于CPU的寄存器,寄存器存储指令相关的现场信息。CPU只有把数据装载到寄存器才能够运行
    2023-02-02

最新评论