Java编写实现九宫格应用

 更新时间:2022年05月05日 08:05:55   作者:shihao9895  
这篇文章主要为大家详细介绍了Java编写实现九宫格应用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了Java编写实现九宫格应用的具体代码,供大家参考,具体内容如下

在九宫格里面轮流画圈或叉,哪一方先在水平、竖直、或对角线上有三个子则胜出。

可在窗体中安排9个按钮对应每个格子

计算机和人轮流下子。

代码如下:

import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
import java.lang.*;
class ChessDemo extends Panel implements ActionListener{
    char whoTurn = 'O';  //人—O,计算机--X
    Button b[] = new Button[9];  //9个按钮
    StringBuffer chess = new StringBuffer("KKKKKKKKK");
     //将九宫格用一位数组来表示,用K字符表示空位置
     
public ChessDemo(){
      setLayout(new GridLayout(3,3,3,3));
      for (int i=0;i<9;i++) {
          b[i] = new Button("");
          add(b[i]);
          b[i].setActionCommand(String.valueOf(i));
          b[i].addActionListener(this);
      }
}
 
public void actionPerformed(ActionEvent e) {
       Button me = (Button)(e.getSource());//自己
       if (!me.getLabel().equals("")) //不允许在已有棋子位置下棋 
            return;
       me.setLabel("" + whoTurn); //标记下棋
       int row = Integer.parseInt(me.getActionCommand()); //求位置
       chess.setCharAt(row,whoTurn); //记录下棋     
       gameOver();  //判游戏是否结束
       whoTurn = (whoTurn=='O') ? 'X' : 'O'; //轮换玩家
       computerTake();  //计算机下
} 
 
public  int  findplace() { //计算机找下棋位置
       for (int r=0;r<9;r++) 
          if (chess.charAt(r)=='K') {    //找个空位置
             chess.setCharAt(r,whoTurn);     //先填上棋子
             if (isWin(whoTurn))  { //看自己下此位置是否能赢 
                 chess.setCharAt(r,'K');  // 恢复原状
                    return r;
             }
             else
                 chess.setCharAt(r,'K');   // 恢复原状
         }
     // 没自己能直接赢得位置再看对方能赢的地方
      char  whoTurn2 = (whoTurn=='O') ? 'X' : 'O'; //换成对方思考
      for (int r=0;r<9;r++) 
            if (chess.charAt(r)=='K') {
             chess.setCharAt(r,whoTurn2);   //在空白处填上对方棋子
             if (isWin(whoTurn2)) {  //看填上棋子后能赢否
                 chess.setCharAt(r,'K');  // 恢复原状
                    return r;
             }
             else
                  chess.setCharAt(r,'K');   //恢复原状
         }
            if (chess.charAt(4)=='K') {   //优先看中央位置
            return 4;      //占据中央,返回4
        }
            else  {
                for (int d=1;d<5;d++) {   // 随机找个空位置
                    int rand= (int)(Math.random() * 9);
                    if (chess.charAt(rand)=='K')
                    return rand;
                }
        }
       return -1;  //特殊返回
}
 
public void computerTake(){
     int x = findplace();  //根据策略找位置
     chess.setCharAt(x,whoTurn);
     b[x].setLabel(String.valueOf(whoTurn));
     gameOver();    
     whoTurn = (whoTurn=='O') ? 'X' : 'O';
}
 
public void gameOver() {
   if (isWin(whoTurn)) { //判是否取胜
       JOptionPane.showMessageDialog(null, whoTurn+" win!");
       System.exit(0);
    } else if (isFull()) { //判是否下满格子
       JOptionPane.showMessageDialog(null, "game is over!");
       System.exit(0);
    }
 }
 
public boolean isWin(char who){   
   String s3 = "" + who + who + who;
   String sum;   
   String sum1;
   String sum2;//用来拼接一个方向的棋子标识
   for(int k=0;k<3;k++)
   {
       sum1=""+chess.charAt(k)+chess.charAt(k+3)+chess.charAt(k+6);//垂直方向
       sum2=""+chess.charAt(k*3+0)+chess.charAt(k*3+1)+chess.charAt(k*3+2);//水平方向
       if(sum1.equals(s3)||sum2.equals(s3))
       {
           return true;
       }
       else
       {
           sum1="";
           continue;
       }
    }
   sum=""+chess.charAt(0)+chess.charAt(4)+chess.charAt(8); //正对角线
   if (sum.equals(s3)) return true;
   sum=""+chess.charAt(2)+chess.charAt(4)+chess.charAt(6); //反对角线
   if (sum.equals(s3)) return true;
   return false;
}
 
public boolean isFull() {  //判是否棋盘下满了
   return chess.toString().indexOf("K")== -1;
}
 
public static void main(String args[]) {
    Frame f = new Frame();
    f.add(new ChessDemo());
    f.setSize(300,300);
    f.setVisible(true); 
}
}

结果如下:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 通过实例解析JMM和Volatile底层原理

    通过实例解析JMM和Volatile底层原理

    这篇文章主要介绍了通过实例解析JMM和Volatile底层原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-01-01
  • 解决IDEA2020控制台乱码的方法

    解决IDEA2020控制台乱码的方法

    这篇文章主要介绍了解决IDEA2020控制台乱码的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • Servlet3.0学习总结之基于Servlet3.0的文件上传实例

    Servlet3.0学习总结之基于Servlet3.0的文件上传实例

    本篇文章主要介绍了Servlet3.0学习总结之基于Servlet3.0的文件上传实例,具有一定的参考价值,有兴趣的可以了解一下
    2017-07-07
  • Java实现简易的分词器功能

    Java实现简易的分词器功能

    搜索功能是具备数据库功能的系统的一大重要特性和功能,生活中常见的搜索功能基本上都具备了分词搜索功能.然而ES功能固然强大,但对于学生或小项目而言整合起来太费人力物力,若是写个分词器就会使项目锦上添花,使其不仅仅是只能单关键词搜索的系统,需要的朋友可以参考下
    2021-06-06
  • Java下载文件的四种方式详细代码

    Java下载文件的四种方式详细代码

    这篇文章介绍了Java下载文件的四种方式,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-12-12
  • springboot如何重定向携带数据 RedirectAttributes

    springboot如何重定向携带数据 RedirectAttributes

    这篇文章主要介绍了springboot如何重定向携带数据 RedirectAttributes,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09
  • 深入理解Spring的事务传播行为

    深入理解Spring的事务传播行为

    spring特有的事务传播行为,spring支持7种事务传播行为,确定客户端和被调用端的事务边界(说得通俗一点就是多个具有事务控制的service的相互调用时所形成的复杂的事务边界控制),这篇文章主要给大家介绍了关于Spring事务传播行为的相关资料,需要的朋友可以参考下。
    2018-02-02
  • java集合求和最大值最小值示例分享

    java集合求和最大值最小值示例分享

    这篇文章主要介绍了java集合求和最大值最小值示例
    2014-01-01
  • SpringBoot中各个层级结构的具体实现

    SpringBoot中各个层级结构的具体实现

    在SpringBoot项目中,常常会把代码文件放入不同的包中,本文主要介绍了SpringBoot中各个层级结构的具体实现,具有一定的参考价值,感兴趣的可以了解一下
    2024-05-05
  • 总结十个实用但偏执的Java编程技术

    总结十个实用但偏执的Java编程技术

    Java是世界上最流行的程序语言,从1995年问世以来,Java的生态系统在一直在蓬勃的发展着。下面这篇文章主要总结了十个实用但偏执的Java编程技术,需要的朋友可以参考借鉴,下面来一起学习学习吧。
    2017-01-01

最新评论