Java控制台版五子棋的简单实现方法

 更新时间:2021年01月31日 13:48:05   作者:钱多多不多余  
这篇文章主要给大家介绍了关于Java控制台版五子棋的简单实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

设计一个10*10的棋盘:

行号、列号单独输出

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();
 }

输入坐标下棋(x,y),并作容错处理:

  1. 保证输入的坐标是(x,y);
  2. 下标越界处理;
  3. 判断此坐标有无棋子;
  4. 确保坐标输入为数字。
int x,y;//储存下棋坐标:
 Scanner sc=new Scanner(System.in);
 boolean flag=true;//区分黑白棋;
 while(true){
 System.out.println("请输入坐标下棋,坐标格式(x,y)");
 String str=sc.nextLine();
 String [] str1=str.split(",");
  //容错处理1
  if(str1.length!=2){
 	 System.out.println("坐标输入错误,请重新输入!!");
 	 
  }else{
  //容错处理3
 	 try{
 		 x=Integer.parseInt(str1[0]);
    y=Integer.parseInt(str1[1]);
 	 }catch(Exception e){
 		 System.out.println("坐标输入错误,请重新输入!!");
 		 continue;
 	 }
 	 //容错处理2--下标越界
 	 if(x>=10||y>=10){
 		 System.out.println("坐标输入错误,请重新输入!!");
 	 }else{
 		 //容错处理--判断当前位置是否有棋子:
 		 //黑白棋:
 		 if(qipan[x][y].equals("+ ")){
 			 if(flag){
 				 qipan[x][y]="● ";
 			 }else{
 				 qipan[x][y]="○ ";
 			 }
 			 flag=!flag;
 		 }else{
 			 System.out.println("当前位置已有棋子,请重新输入坐标!!");
 			 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个方向,4条线

  1. 上方&下方
  2. 左方&右方
  3. 左斜上&右斜下
  4. 右斜上&左斜下
//判断是否五子连珠:
 		  int count=1;
 		  String currentZiQi=qipan[x][y];//储存当前下的棋子;
 		 //判断上方:
 		  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;
  		}
 	 }
 	 
 	 
  } 
 }
 }

总结

到此这篇关于Java控制台版五子棋的简单实现方法的文章就介绍到这了,更多相关Java控制台版五子棋内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JDBC数据源连接池配置及应用

    JDBC数据源连接池配置及应用

    这篇文章主要介绍JDBC建立数据库连接的两种方式,使用配置数据源的方式连接数据库,效率更高,推荐使用,希望能给大家做一个参考。
    2016-06-06
  • Java将字符串转化为数组的两种方法

    Java将字符串转化为数组的两种方法

    Java中的String类是一种特殊的字符串,它可以被用于处理字符串,Java中的String类也可以将字符串转换为数组,下面这篇文章主要给大家介绍了关于Java将字符串转化为数组的两种方法,需要的朋友可以参考下
    2023-05-05
  • java实现删除某条信息并刷新当前页操作

    java实现删除某条信息并刷新当前页操作

    这篇文章主要介绍了java实现删除某条信息并刷新当前页操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • Flink状态和容错源码解析

    Flink状态和容错源码解析

    这篇文章主要为大家介绍了Flink状态和容错源码示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • resty client使用Java客户端来访问Api

    resty client使用Java客户端来访问Api

    这篇文章主要介绍了resty-client使用Java客户端来访问Api的验证权限,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-03-03
  • Java 通过位运算求一个集合的所有子集方法

    Java 通过位运算求一个集合的所有子集方法

    下面小编就为大家带来一篇Java 通过位运算求一个集合的所有子集方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03
  • Java 线程状态和等待唤醒机制和线程池的实现

    Java 线程状态和等待唤醒机制和线程池的实现

    这篇文章主要介绍了Java 线程状态和等待唤醒机制和线程池的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • Spring内部bean和级联属性用法详解

    Spring内部bean和级联属性用法详解

    这篇文章主要介绍了Java内部bean和级联属性用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • spring boot security 没有合适的构造器问题

    spring boot security 没有合适的构造器问题

    这篇文章主要介绍了spring boot security 没有合适的构造器问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Java访问者模式实现优雅的对象结构处理

    Java访问者模式实现优雅的对象结构处理

    Java访问者模式是一种行为型设计模式,它通过将数据结构和数据操作分离,实现对复杂对象结构的处理。它将数据结构中的每个元素都转换为访问者能够识别的形式,从而使得数据操作可以在不影响数据结构的前提下进行扩展和变化
    2023-04-04

最新评论