java控制臺版實現(xiàn)五子棋游戲
控制臺實現(xiàn)五子棋游戲,供大家參考,具體內(nèi)容如下
控制臺打印棋盤 編寫兩人對弈的五子棋游戲,游戲規(guī)則:黑白雙方有一方首先實現(xiàn)五子連續(xù),則獲勝,游戲結(jié)束。代碼:
import java.util.Scanner;public class Wuziqi { //自定義二維數(shù)組來描述棋盤,默認(rèn)初始值為0 int[][] chessBoard = new int[16][16]; //自定義成員方法來繪制棋盤 void paint(){ //1.先繪制棋盤中第一行的坐標(biāo)信息,也就是列坐標(biāo)信息 for (int i = 0; i < 17; i++) { if( 0 == i){System.out.println(' '); }else {//按照16進(jìn)制打印i-1的數(shù)值System.out.printf('%x ' , i - 1); } } System.out.println(); //2.繪制棋盤中除了第一行之外的其他部分以及行坐標(biāo)信息 for (int i = 0; i < 16; i++) { //用于打印行坐標(biāo)信息 System.out.printf('%x ', i); for (int j = 0; j < 16; j++) {//剛開始棋盤中所有內(nèi)容都是+ , 因此直接打印if (0 == chessBoard[i][j]){ System.out.print('+ ');} else if (1 == chessBoard[i][j]){ System.out.print('● ');}else { System.out.print('○ ');} } //打印完一行的所有內(nèi)容之后進(jìn)行換行 System.out.println(); } } //自定義成員方法來提示黑方和白方分別下棋 void play(){ //定義標(biāo)志位來進(jìn)行黑方和白方的切換,true代表黑方,false代表白方 boolean flag = true; //不斷地分別提示黑方和白方下棋 while(true){ System.out.println('請' + (flag ? '黑方' : '白方') + '輸入落子坐標(biāo)(x,y):'); Scanner sc = new Scanner(System.in); int x = sc.nextInt(); int y = sc.nextInt(); //根據(jù)用戶輸入的坐標(biāo)來調(diào)整棋盤中的圖案,策略為改變數(shù)值的元素值, //當(dāng)黑子落子時就將數(shù)組中對應(yīng)的元素值改為1,當(dāng)白方落子時就將數(shù)組中對應(yīng)的元素改為2 chessBoard[x][y] = (flag ? 1 : 2); //重新繪制圖案 paint(); //判斷當(dāng)前方是否勝利,若勝利就結(jié)束游戲 if (Success(x, y)) {System.out.println('恭喜' + (flag ? '黑方' : '白方') + '勝利了!');break; } // 此時切換下棋方 flag = !flag; } } //自定義成員方法來判斷用戶是否獲勝,獲勝的規(guī)則時:任意相同顏色的5個棋子連成一條線 boolean Success(int x, int y){ //1.判斷豎向是否連成一線,則需要以該點為中心向上四個點向下四個點 //聲明變量來統(tǒng)計豎向相同顏色棋子的個數(shù),先統(tǒng)計向上同色棋子的個數(shù) //先統(tǒng)計向上顏色相同的個數(shù) int count = 1; for (int i = x - 1; i >= 0; i--) { //若當(dāng)前點代表的棋子與上述某個點代表的棋子不一樣,則向上統(tǒng)計結(jié)束 if (chessBoard[x][y] != chessBoard[i][y]){break; } count++; } //再統(tǒng)計向下顏色相同的個數(shù) for (int i = x + 1; i < chessBoard.length; i++) { if (chessBoard[x][y] != chessBoard[i][y]){break; } count++; } if (5 == count){ return true; } //2.判斷橫向是否連成一條線,則需要以該店為中心向左四個點向右四個點 count = 1; //先統(tǒng)計向左顏色相同的個數(shù) for (int j = y - 1; j >= 0; j--) { //若當(dāng)前點代表的棋子與上述某個點代碼的棋子不一樣,則向上統(tǒng)計結(jié)束 if (chessBoard[x][y] != chessBoard[x][j]) {break; } count++; } //再統(tǒng)計向右顏色相同的個數(shù) for (int j = y + 1; j < chessBoard.length; j++) { if(chessBoard[x][y] != chessBoard[x][j]){break; } count++; } if (5 == count){ return true; } // 3.判斷左上到右下是否連成一線,則需要以該點為中心向左上四個點向右下四個點 count = 1; // 先統(tǒng)計左上顏色相同的個數(shù) for (int i = x-1, j = y - 1; i >= 0 && j >= 0; i--, j--) { // 若當(dāng)前點代表的棋子與上述某個點代表的棋子不一樣,則向上統(tǒng)計結(jié)束 if (chessBoard[x][y] != chessBoard[i][j]) {break; } count++; } // 再統(tǒng)計右下顏色相同的個數(shù) for (int i = x+1, j = y + 1; i <= 15 && j <= 15; i++, j++) { if (chessBoard[x][y] != chessBoard[i][j]) {break; } count++; } if (5 == count) { return true; } // 4.判斷右上到左下是否連成一線,則需要以該點為中心向右上四個點向左下四個點 count = 1; // 先統(tǒng)計右上顏色相同的個數(shù) for (int i = x-1, j = y + 1; i >= 0 && j <= 15; i--, j++) { // 若當(dāng)前點代表的棋子與上述某個點代表的棋子不一樣,則向上統(tǒng)計結(jié)束 if (chessBoard[x][y] != chessBoard[i][j]) {break; } count++; } // 再統(tǒng)計左下顏色相同的個數(shù) for (int i = x+1, j = y - 1; i <= 15 && j >= 0; i++, j--) { if (chessBoard[x][y] != chessBoard[i][j]) {break; } count++; } if (5 == count) { return true; } // 當(dāng)上述所有情況都不成立時,表示該下棋方?jīng)]有獲勝 return false; }}
public class WuziqiTest { public static void main(String[] args) { //聲明一個Wuziqi類型的引用指向Wuziqi類型的對象 Wuziqi wz = new Wuziqi(); //調(diào)用paint()方法打印列信息 wz.paint(); //下棋開始 wz.play(); }}
結(jié)果如下
文中沒有對下棋時候的數(shù)組下標(biāo)進(jìn)行合理值判斷,各位可自行完善。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. IntelliJ IDEA設(shè)置默認(rèn)瀏覽器的方法2. HTTP協(xié)議常用的請求頭和響應(yīng)頭響應(yīng)詳解說明(學(xué)習(xí))3. idea設(shè)置提示不區(qū)分大小寫的方法4. CentOS郵件服務(wù)器搭建系列—— POP / IMAP 服務(wù)器的構(gòu)建( Dovecot )5. IntelliJ IDEA創(chuàng)建web項目的方法6. VMware中如何安裝Ubuntu7. docker容器調(diào)用yum報錯的解決辦法8. .NET SkiaSharp 生成二維碼驗證碼及指定區(qū)域截取方法實現(xiàn)9. 原生JS實現(xiàn)記憶翻牌游戲10. ASP.NET MVC通過勾選checkbox更改select的內(nèi)容
