欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java實現(xiàn)五子棋的基礎(chǔ)方法

 更新時間:2020年09月03日 13:42:15   作者:MSJ_743579531  
這篇文章主要為大家詳細介紹了Java實現(xiàn)五子棋的基礎(chǔ)方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了Java實現(xiàn)五子棋的具體代碼,供大家參考,具體內(nèi)容如下

任務(wù)概述:

五子棋是全國智力運動會競技項目之一,是一種兩人對弈的純策略型棋類游戲。通常雙方分別使用黑白兩色的棋子,下在棋盤直線與橫線的交叉點上,先形成五子連線者獲勝。

任務(wù)過程:

1.繪制棋盤
2.提示黑方(用 1 表示)和白方(用 2 表示)分別下棋(X,Y 軸位置)并重新繪制棋盤
3.每當(dāng)一方下棋后判斷是否獲勝

重點講解:

1.關(guān)于勝利的判斷:

根據(jù)用戶所下棋子的位置對其周圍進行檢測,分為以下情況:
橫向:當(dāng)前下棋位置左右各4顆棋子連續(xù)相同5顆
豎向:當(dāng)前下棋位置上下各4顆棋子連續(xù)相同5顆
斜向:當(dāng)前下棋位置左上右下各4顆棋子連續(xù)相同5顆、當(dāng)前下棋位置左下右上各4顆棋子連續(xù)相同5顆
在檢測時要注意數(shù)組的下標(biāo),若用戶下棋位置處于棋盤邊緣,則周圍坐標(biāo)很可能已經(jīng)在棋盤之外,要注意加上相應(yīng)的判斷避免下標(biāo)越界!

2.關(guān)于棋盤下滿:

我的思路是,先認為棋盤已經(jīng)下滿,然后在打印棋盤的同時,若當(dāng)前打印值為0,則認為棋盤未滿,可繼續(xù)下棋操作,若棋盤已經(jīng)打印完畢,仍然沒有打印值為0的情況,則認為棋盤下滿,雙方平局,游戲結(jié)束。

其余內(nèi)容在代碼上有詳細的注釋,以下為代碼:

import java.util.Scanner;

public class Chess {

 public static void main(String[] args) {
 Scanner scanner = new Scanner(System.in);
 int order = 1;//儲存順序,當(dāng)order為1時輪到黑方下棋,當(dāng)order為2時輪到白方下棋
 int row = 0;//用來儲存要下棋的行數(shù)
 int column = 0;//用來儲存要下棋的列數(shù)
 int win = 0;//用來儲存獲勝者編號,為0則雙方均未獲勝,為1則白方獲勝,為2則黑方獲勝
 int count1 = 0;//用來儲存當(dāng)前下棋位置左右各4顆棋子的相同數(shù)量
 int count2 = 0;//用來儲存當(dāng)前下棋位置上下各4顆棋子的相同數(shù)量
 int count3 = 0;//用來儲存當(dāng)前下棋位置左上右下各4顆棋子的相同數(shù)量
 int count4 = 0;//用來儲存當(dāng)前下棋位置左下右上各4顆棋子的相同數(shù)量
 int full = 1;//用來判斷棋盤是否下滿,默認值1認為已滿,只要有1處空則置0
 int board[][] = new int[16][16];//用來記錄棋盤
 
 //為棋盤的坐標(biāo)賦值
 for(int i = 0;i<16;i++) {
  board[i][0] = i;//為棋盤的Y軸賦值
 }
 for(int j = 0;j<16;j++) {
  board[0][j] = j;//為棋盤的X軸賦值
 }
 
 //開始下棋,無限循環(huán)直到有一方勝利或棋盤下滿
 while(true) {
  
  //首先輸出棋盤
  for(int i = 0;i<16;i++) {
  for(int j = 0;j<16;j++) {
   if(board[i][j] == 0)//若棋盤有1處空則認為棋盤未滿
   full = 0;
   System.out.print(board[i][j]+"\t");
  }
  System.out.println();
  }
  
  //然后判斷棋盤是否下滿
  if(full == 1) {//棋盤自始至終未有空值,則認為棋盤已經(jīng)下滿
  System.out.print("棋盤已下滿,雙方平局,游戲結(jié)束!");
  break;//跳出循環(huán)
  }
  
  //棋盤未滿,進入下棋過程
  if(order == 1) {//order為1黑方下棋
  order = 2;//切換order,下一次則白方下棋
  //無限循環(huán)直到下棋點可以正常下棋
  while(true) {
   System.out.println("請黑方下棋,請先輸入X軸位置(列數(shù),1-15):");
   column = scanner.nextInt();//儲存要下棋的列數(shù)
   System.out.println("請黑方下棋,請輸入Y軸位置(行數(shù),1-15):");
   row = scanner.nextInt();//儲存要下棋的行數(shù)
   if(board[row][column] != 0)//下棋點已有棋子,需重新下棋
   System.out.println("此次下棋無效,請重新下棋!");
   else {
   board[row][column] = 1;//放置黑棋
   break;//跳出循環(huán)
   }
  }
  }
  else {//order為2白方下棋
  order = 1;//切換order,下一次則黑方下棋
  //無限循環(huán)直到下棋點可以正常下棋
  while(true) {
   System.out.println("請白方下棋,請先輸入X軸位置(列數(shù),1-15):");
   column = scanner.nextInt();//儲存要下棋的列數(shù)
   System.out.println("請白方下棋,請輸入Y軸位置(行數(shù),1-15):");
   row = scanner.nextInt();//儲存要下棋的行數(shù)
   if(board[row][column] != 0)//下棋點已有棋子,需重新下棋
   System.out.println("此次下棋無效,請重新下棋!");
   else {
   board[row][column] = 2;//放置白棋
   break;//跳出循環(huán)
   }
  }
  }
  
  //本次下棋完畢,判斷是否有人獲勝
  for(int i = -4;i < 4;i++) {
  
  //判斷當(dāng)前下棋位置左右各4顆棋子的相同數(shù)量,連續(xù)4組相同則獲勝
  if(column+i>0 && column+i+1<16) {//防止下標(biāo)越界
   if(board[row][column+i] == board[row][column+i+1] && board[row][column+i] != 0) {
   count1++;
   if(count1 == 4) {//連續(xù)4組相同,獲勝
    win = order;
    break;
   }
   }
   else
   count1 = 0;//未連續(xù)相同,清除相同計數(shù)
  }
  
  //判斷當(dāng)前下棋位置上下各4顆棋子的相同數(shù)量,連續(xù)4組相同則獲勝
  if(row+i>0 && row+i+1<16) {//防止下標(biāo)越界
   if(board[row+i][column] == board[row+i+1][column] && board[row+i][column] != 0) {
   count2++;
   if(count2 == 4) {//連續(xù)4組相同,獲勝
    win = order;
    break;
   }
   }
   else
   count2 = 0;//未連續(xù)相同,清除相同計數(shù)
  }
  
  //判斷當(dāng)前下棋位置左上右下各4顆棋子的相同數(shù)量,連續(xù)4組相同則獲勝
  if(column+i>0 && column+i+1<16 && row+i>0 && row+i+1<16) {//防止下標(biāo)越界
   if(board[row+i][column+i] == board[row+i+1][column+i+1] && board[row+i][column+i] != 0) {
   count3++;
   if(count3 == 4) {//連續(xù)4組相同,獲勝
    win = order;
    break;
   }
   }
   else
   count3 = 0;//未連續(xù)相同,清除相同計數(shù)
  }
  
  //判斷當(dāng)前下棋位置左下右上各4顆棋子的相同數(shù)量,連續(xù)4組相同則獲勝
  if(column+i>0 && column+i+1<16 && row-i-1>0 && row-i<16) {//防止下標(biāo)越界
   if(board[row-i][column+i] == board[row-i-1][column+i+1] && board[row-i][column+i] != 0) {
   count4++;
   if(count4 == 4) {//連續(xù)4組相同,獲勝
    win = order;
    break;
   }
   }
   else
   count4 = 0;//未連續(xù)相同,清除相同計數(shù)
  }
  
  }
  
  //有人獲勝,輸出棋盤及獲勝者,跳出循環(huán)
  if(win == 2) {//由于win是order的值,order輪到白方,說明黑方獲勝
  //輸出棋盤
  for(int i = 0;i<16;i++) {
   for(int j = 0;j<16;j++) {
   System.out.print(board[i][j]+"\t");
   }
   System.out.println();
  }
  System.out.println("恭喜黑方獲勝,游戲結(jié)束!");
  break;//跳出循環(huán)
  }
  else if(win == 1) {//由于win是order的值,order輪到黑方,說明白方獲勝
  //輸出棋盤
  for(int i = 0;i<16;i++) {
   for(int j = 0;j<16;j++) {
   System.out.print(board[i][j]+"\t");
   }
   System.out.println();
  }
  System.out.println("恭喜白方獲勝,游戲結(jié)束!");
  break;//跳出循環(huán)
  }
  
  //無人獲勝,清除相同棋子計數(shù),開始新循環(huán)
  count1 = 0;
  count2 = 0;
  count3 = 0;
  count4 = 0;
  full = 1;//再次認為棋盤已滿
 
 }
 }

}

更多有趣的經(jīng)典小游戲?qū)崿F(xiàn)專題,分享給大家:

C++經(jīng)典小游戲匯總

python經(jīng)典小游戲匯總

python俄羅斯方塊游戲集合

JavaScript經(jīng)典游戲 玩不停

javascript經(jīng)典小游戲匯總

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java Web編程之Servlet技術(shù)詳解

    Java Web編程之Servlet技術(shù)詳解

    這篇文章主要為大家詳細介紹了Java Web編程之Servlet技術(shù),Servlet就是一種實現(xiàn)了Servlet接口的類,它由Web容器(Tomcat/Jetty等)負責(zé)調(diào)用并創(chuàng)建,用于接收和響應(yīng)用戶請求,感興趣的小伙伴們可以參考一下
    2016-05-05
  • Java核心庫實現(xiàn)簡單的AOP

    Java核心庫實現(xiàn)簡單的AOP

    這篇文章主要介紹了如何用Java核心庫實現(xiàn)簡單的AOP,幫助大家為了更好的理解和學(xué)習(xí)AOP的思想,感興趣的朋友可以了解下
    2020-08-08
  • Spring多定時任務(wù)@Scheduled執(zhí)行阻塞問題解決

    Spring多定時任務(wù)@Scheduled執(zhí)行阻塞問題解決

    這篇文章主要介紹了Spring多定時任務(wù)@Scheduled執(zhí)行阻塞問題解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • Feign遠程調(diào)用參數(shù)里面內(nèi)容丟失的解決方案

    Feign遠程調(diào)用參數(shù)里面內(nèi)容丟失的解決方案

    這篇文章主要介紹了Feign遠程調(diào)用參數(shù)里面內(nèi)容丟失的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Java 數(shù)據(jù)結(jié)構(gòu)線性表之順序存儲詳解原理

    Java 數(shù)據(jù)結(jié)構(gòu)線性表之順序存儲詳解原理

    線性表的順序存儲是指用一組地址連續(xù)的存儲單元依次存儲線性表中的各個元素、使得線性表中在邏輯結(jié)構(gòu)上相鄰的數(shù)據(jù)元素存儲在相鄰的物理存儲單元中,即通過數(shù)據(jù)元素物理存儲的相鄰關(guān)系來反映數(shù)據(jù)元素之間邏輯上的相鄰關(guān)系
    2021-10-10
  • Java mail 發(fā)送郵件的具體實例

    Java mail 發(fā)送郵件的具體實例

    這篇文章主要介紹了Java mail 發(fā)送郵件的具體實例,需要的朋友可以參考下
    2014-02-02
  • 全面剖析java中的注解(Annotation)

    全面剖析java中的注解(Annotation)

    一個詞就可以描述注解,那就是元數(shù)據(jù),即一種描述數(shù)據(jù)的數(shù)據(jù)。所以,可以說注解就是源代碼的元數(shù)據(jù)。文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • JVM的內(nèi)存回收及常見算法小結(jié)

    JVM的內(nèi)存回收及常見算法小結(jié)

    這篇文章主要介紹了JVM的內(nèi)存回收及常見算法,需要的朋友可以參考下
    2023-05-05
  • java使用反射訪問成員變量的值示例

    java使用反射訪問成員變量的值示例

    這篇文章主要介紹了java使用反射訪問成員變量的值,結(jié)合實例形式分析了java基于反射機制操作類成員變量相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2019-07-07
  • java多線程實現(xiàn)取款小程序

    java多線程實現(xiàn)取款小程序

    這篇文章主要為大家詳細介紹了java多線程實現(xiàn)取款小程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05

最新評論