文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Java编写实现九宫格应用

2024-04-02 19:55

关注

本文实例为大家分享了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); 
}
}

结果如下:

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

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯