linux控制台单人五子棋简书,Java控制台版五子棋的简单实现方法
這篇文章主要給大家介紹了關(guān)于Java控制臺版五子棋的簡單實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
設(shè)計(jì)一個(gè)10*10的棋盤:
行號、列號單獨(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
for(int q=0;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
System.out.print(k+" ");
for(int q=0;q
System.out.print(qipan[k][q]);
}
System.out.println();
}//加入Java開發(fā)交流君樣:756584822一起吹水聊天
輸入坐標(biāo)下棋(x,y),并作容錯處理:
保證輸入的坐標(biāo)是(x,y);
下標(biāo)越界處理;
判斷此坐標(biāo)有無棋子;
確保坐標(biāo)輸入為數(shù)字。
int x,y;//儲存下棋坐標(biāo):
Scanner sc=new Scanner(System.in);
boolean flag=true;//區(qū)分黑白棋;
while(true){
System.out.println("請輸入坐標(biāo)下棋,坐標(biāo)格式(x,y)");
String str=sc.nextLine();
String [] str1=str.split(",");
//容錯處理1
if(str1.length!=2){
System.out.println("坐標(biāo)輸入錯誤,請重新輸入!!");
}else{
//容錯處理3
try{
x=Integer.parseInt(str1[0]);
y=Integer.parseInt(str1[1]);
}catch(Exception e){
System.out.println("坐標(biāo)輸入錯誤,請重新輸入!!");
continue;
}
//容錯處理2--下標(biāo)越界
if(x>=10||y>=10){
System.out.println("坐標(biāo)輸入錯誤,請重新輸入!!");
}else{
//容錯處理--判斷當(dāng)前位置是否有棋子:
//黑白棋:
if(qipan[x][y].equals("+ ")){
if(flag){
qipan[x][y]="● ";
}else{
qipan[x][y]="○ ";
}//加入Java開發(fā)交流君樣:756584822一起吹水聊天
flag=!flag;
}else{
System.out.println("當(dā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
System.out.print(k+" ");
for(int q=0;q
System.out.print(qipan[k][q]);
}
System.out.println();
}
判斷是否五子連珠:
8個(gè)方向,4條線
上方&下方
左方&右方
左斜上&右斜下
右斜上&左斜下
//判斷是否五子連珠:
int count=1;
String currentZiQi=qipan[x][y];//儲存當(dāng)前下的棋子;
//判斷上方://加入Java開發(fā)交流君樣:756584822一起吹水聊天
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;
}
}//加入Java開發(fā)交流君樣:756584822一起吹水聊天
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;
}
}
}
}
}
[
image
最新2020整理收集的一些高頻面試題(都整理成文檔),有很多干貨,包含mysql,netty,spring,線程,spring cloud、jvm、源碼、算法等詳細(xì)講解,也有詳細(xì)的學(xué)習(xí)規(guī)劃圖,面試題整理等,需要獲取這些內(nèi)容的朋友請加Q君樣:756584822
總結(jié)
以上是生活随笔為你收集整理的linux控制台单人五子棋简书,Java控制台版五子棋的简单实现方法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux虚拟化毕业设计,毕业设计(论文
- 下一篇: c语言程序中的注释必须单独占一行,C语言