Java控制臺(tái)版五子棋的簡(jiǎn)單實(shí)現(xiàn)方法
設(shè)計(jì)一個(gè)10*10的棋盤:
行號(hào)、列號(hào)單獨(dú)輸出
package yu;
import java.util.Scanner;
public class WuZiQi {
/*● 棋子1
○ 棋子2
*
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
String [] [] qipan=new String [10] [10];
//初始化棋盤:
for(int k=0;k<qipan.length;k++){
for(int q=0;q<qipan[k].length;q++){
qipan[k][q]="+ ";
}
}
//輸出棋盤:
System.out.print(" ");
for(int i=0;i<10;i++){
System.out.print(i+" ");
}
System.out.println();
for(int k=0;k<qipan.length;k++){
System.out.print(k+" ");
for(int q=0;q<qipan[k].length;q++){
System.out.print(qipan[k][q]);
}
System.out.println();
}
輸入坐標(biāo)下棋(x,y),并作容錯(cuò)處理:
- 保證輸入的坐標(biāo)是(x,y);
- 下標(biāo)越界處理;
- 判斷此坐標(biāo)有無(wú)棋子;
- 確保坐標(biāo)輸入為數(shù)字。
int x,y;//儲(chǔ)存下棋坐標(biāo):
Scanner sc=new Scanner(System.in);
boolean flag=true;//區(qū)分黑白棋;
while(true){
System.out.println("請(qǐng)輸入坐標(biāo)下棋,坐標(biāo)格式(x,y)");
String str=sc.nextLine();
String [] str1=str.split(",");
//容錯(cuò)處理1
if(str1.length!=2){
System.out.println("坐標(biāo)輸入錯(cuò)誤,請(qǐng)重新輸入!!");
}else{
//容錯(cuò)處理3
try{
x=Integer.parseInt(str1[0]);
y=Integer.parseInt(str1[1]);
}catch(Exception e){
System.out.println("坐標(biāo)輸入錯(cuò)誤,請(qǐng)重新輸入!!");
continue;
}
//容錯(cuò)處理2--下標(biāo)越界
if(x>=10||y>=10){
System.out.println("坐標(biāo)輸入錯(cuò)誤,請(qǐng)重新輸入!!");
}else{
//容錯(cuò)處理--判斷當(dāng)前位置是否有棋子:
//黑白棋:
if(qipan[x][y].equals("+ ")){
if(flag){
qipan[x][y]="● ";
}else{
qipan[x][y]="○ ";
}
flag=!flag;
}else{
System.out.println("當(dāng)前位置已有棋子,請(qǐng)重新輸入坐標(biāo)!!");
continue;
}
//輸出棋盤:
System.out.print(" ");
for(int i=0;i<10;i++){
System.out.print(i+" ");
}
System.out.println();
for(int k=0;k<qipan.length;k++){
System.out.print(k+" ");
for(int q=0;q<qipan[k].length;q++){
System.out.print(qipan[k][q]);
}
System.out.println();
}
判斷是否五子連珠:
8個(gè)方向,4條線
- 上方&下方
- 左方&右方
- 左斜上&右斜下
- 右斜上&左斜下
//判斷是否五子連珠:
int count=1;
String currentZiQi=qipan[x][y];//儲(chǔ)存當(dāng)前下的棋子;
//判斷上方:
for(int k=x-1;k>=0;k--){
if(qipan[k][y].equals(currentZiQi)){
count++;
}else{
break;
}
}
if(count>=5){
System.out.println(currentZiQi+"獲勝!??!");
break;
}
//判斷下方:
for(int k=x+1;k<10;k++){
if(qipan[k][y].equals(currentZiQi)){
count++;
}else{
break;
}
}
if(count>=5){
System.out.println(currentZiQi+"獲勝?。?!");
break;
}
count=1;//重置count;
//判斷左邊:
for(int k=y-1;k>=0;k--){
if(qipan[x][k].equals(currentZiQi)){
count++;
}else{
break;
}
}
if(count>=5){
System.out.println(currentZiQi+"獲勝?。。?);
break;
}
//判斷右邊:
for(int k=y+1;k<10;k++){
if(qipan[x][k].equals(currentZiQi)){
count++;
}else{
break;
}
}
if(count>=5){
System.out.println(currentZiQi+"獲勝?。?!");
break;
}
count=1;
//判斷左上斜邊:
for(int k=x-1,j=y-1;k>=0&&j>=0;k--,j--){
if(qipan[k][j].equals(currentZiQi)){
count++;
}else{
break;
}
}
if(count>=5){
System.out.println(currentZiQi+"獲勝!?。?);
break;
}
//右下斜方:
for(int k=x+1,j=y+1;k<10&&j<10;k++,j++){
if(qipan[k][j].equals(currentZiQi)){
count++;
}else{
break;
}
}
if(count>=5){
System.out.println(currentZiQi+"獲勝?。?!");
break;
}
count=1;
//左下斜方:
for(int k=x-1,j=y+1;k>=0&&j<10;k--,j++){
if(qipan[k][j].equals(currentZiQi)){
count++;
}else{
break;
}
}
if(count>=5){
System.out.println(currentZiQi+"獲勝!??!");
break;
}
//右上斜方:
for(int k=x+1,j=y-1;k<10&&j>=0;k++,j--){
if(qipan[k][j].equals(currentZiQi)){
count++;
}else{
break;
}
}
if(count>=5){
System.out.println(currentZiQi+"獲勝?。?!");
break;
}
count=1;
}
}
}
}
}
總結(jié)
到此這篇關(guān)于Java控制臺(tái)版五子棋的簡(jiǎn)單實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)Java控制臺(tái)版五子棋內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- java實(shí)現(xiàn)簡(jiǎn)單控制臺(tái)五子棋游戲
- java控制臺(tái)版實(shí)現(xiàn)五子棋游戲
- java實(shí)現(xiàn)五子棋小游戲
- java實(shí)現(xiàn)單機(jī)版五子棋
- java基于swing實(shí)現(xiàn)的五子棋游戲代碼
- Java實(shí)現(xiàn)五子棋網(wǎng)絡(luò)版
- Java實(shí)現(xiàn)兩人五子棋游戲(二) 畫出棋盤
- java實(shí)現(xiàn)單人版五子棋游戲
- Java編程實(shí)現(xiàn)五子棋人人對(duì)戰(zhàn)代碼示例
- Java實(shí)現(xiàn)五子棋AI算法
相關(guān)文章
IntelliJ IDEA下SpringBoot如何指定某一個(gè)配置文件啟動(dòng)項(xiàng)目
這篇文章主要介紹了IntelliJ IDEA下SpringBoot如何指定某一個(gè)配置文件啟動(dòng)項(xiàng)目問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
Spring boot 總結(jié)之跨域處理cors的方法
本篇文章主要介紹了Spring boot 總結(jié)之跨域處理cors的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-02-02
logback使用MDCFilter日志過(guò)濾源碼解讀
這篇文章主要介紹了logback使用MDCFilter日志過(guò)濾源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11
Java基本類型包裝類概述與Integer類、Character類用法分析
這篇文章主要介紹了Java基本類型包裝類概述與Integer類、Character類用法,結(jié)合實(shí)例形式分析了java基本數(shù)據(jù)類型與字符串轉(zhuǎn)換相關(guān)操作技巧,需要的朋友可以參考下2019-03-03
由淺到深帶你詳談Java實(shí)現(xiàn)數(shù)組擴(kuò)容的三種方式
這篇文章主要詳細(xì)介紹了Java實(shí)現(xiàn)數(shù)組擴(kuò)容的三種方式,新建一個(gè)數(shù)組,把原來(lái)數(shù)組的內(nèi)容搬到新數(shù)組中,使用system.arraycopy(),使用java.util.Arrays.copyOf()這三種方式,具有一定的參考價(jià)值,需要的朋友可以借鑒一下2023-06-06
詳解javaweb中jstl如何循環(huán)List中的Map數(shù)據(jù)
這篇文章主要介紹了詳解javaweb中jstl如何循環(huán)List中的Map數(shù)據(jù)的相關(guān)資料,希望通過(guò)本文能幫助到大家,讓大家理解掌握這部分內(nèi)容,需要的朋友可以參考下2017-10-10
Java如何使用正則表達(dá)式從字符串中提取數(shù)字
這篇文章主要介紹了Java如何使用正則表達(dá)式從字符串中提取數(shù)字問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12
Java動(dòng)態(tài)代理靜態(tài)代理實(shí)例分析
這篇文章主要介紹了Java動(dòng)態(tài)代理靜態(tài)代理實(shí)例分析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03

