井字棋游戏初步完成
实现功能:输入位置数据->打印棋盘->判断是否胜利->继续游戏/退出游戏
缺点:没有清屏函数   判断胜利方法太过无脑 
 
 package MYGAME;

 import java.util.Scanner;

 public class Mygame {
static int winnerx = 0;
static int winnero = 0;
static int row; // 行
static int rank; // 行
static int[][] x = new int[3][3]; // X玩家的棋子
static int[][] o = new int[3][3]; // O玩家的棋子 public static void main(String[] args) {
inputmap();
for (int p = 0; p < 9; p++) {
if (p % 2 == 1) {
oplay();
if (winnero==1){
System.out.println("o选手胜利");
break;
}
} else {
xplay();
if (winnerx==1){
System.out.println("x选手胜利");
break;
}
}
}
System.out.println("游戏结束");
} // 输出棋盘
public static void inputmap() {
System.out.println(" ");
for (int m = 0; m < 3; m++) {
for (int n = 0; n < 3; n++) {
if (x[m][n] == 1) {
System.out.print("x|");
} else if (o[m][n] == 1) {
System.out.print("o|");
} else {
System.out.print(" |");
}
}
System.out.println(" ");
}
} // x选手开始下棋
public static void xplay() {
Scanner input = new Scanner(System.in);
System.out.print("轮到x选手下棋\n");
System.out.print("请选择第几行\n");
row = input.nextInt() - 1;
System.out.print("请选择第几列\n");
rank = input.nextInt() - 1;
x[row][rank] = 1;
inputmap();
win();
} // o选手开始下棋
public static void oplay() {
Scanner input = new Scanner(System.in);
System.out.print("轮到o选手下棋\n");
System.out.print("请选择第几行\n");
row = input.nextInt() - 1;
System.out.print("请选择第几列\n");
rank = input.nextInt() - 1;
o[row][rank] = 1;
inputmap();
win();
} // 手动清屏=。=
public static void cleanscreen() {
for (int i = 0; i < 50; i++) {
System.out.println("");
}
} //判断是否胜利
public static void win() {
if (
(x[0][0] == 1 & x[1][0] == 1 & x[2][0] == 1)||
(x[0][1] == 1 & x[1][1] == 1 & x[2][1] == 1)||
(x[0][2] == 1 & x[1][2] == 1 & x[2][2] == 1)||
(x[0][0] == 1 & x[0][1] == 1 & x[0][2] == 1)||
(x[1][0] == 1 & x[1][1] == 1 & x[1][2] == 1)||
(x[2][0] == 1 & x[2][1] == 1 & x[2][2] == 1)||
(x[0][0] == 1 & x[1][1] == 1 & x[2][2] == 1)||
(x[0][2] == 1 & x[1][1] == 1 & x[2][0] == 1)
){
winnerx=1;
}
if (
(o[0][0] == 1 & o[1][0] == 1 & o[2][0] == 1)||
(o[0][1] == 1 & o[1][1] == 1 & o[2][1] == 1)||
(o[0][2] == 1 & o[1][2] == 1 & o[2][2] == 1)||
(o[0][0] == 1 & o[0][1] == 1 & o[0][2] == 1)||
(o[1][0] == 1 & o[1][1] == 1 & o[1][2] == 1)||
(o[2][0] == 1 & o[2][1] == 1 & o[2][2] == 1)||
(o[0][0] == 1 & o[1][1] == 1 & o[2][2] == 1)||
(o[0][2] == 1 & o[1][1] == 1 & o[2][0] == 1)
){
winnero=1;
}
} }

Java 小游戏 - 井字棋 v1.0 (初步完成) (2018.4.16更新)的更多相关文章

  1. Pascal小游戏 井字棋

    一个很经典的井字棋游戏 Pascal源码Chaobs奉上 注意:1.有的FP版本不支持汉语,将会出现乱码.2.别想赢电脑了,平手不错了. 井字过三关: program TicTacToe; uses ...

  2. C++小游戏——井字棋

    #include<cstdio> #include<windows.h> #include<ctime> int main() { srand(time(NULL) ...

  3. Java实现简单井字棋

    Java第一次实验,老师让做一个井字棋,电脑随机下棋. 然后就想能不能聪明一点,可以判断出走哪一步棋:然后只能做到不会输,还是不够聪明,只能呆板地堵住用户,smartRobot的第三个判断逻辑找不到最 ...

  4. python 游戏(井字棋)

    1. 游戏思路和流程图 实现功能,现实生活中的井字棋玩法 游戏流程图 2. 使用模块和游戏提示 import random def game_info(): print('欢迎来到井字棋游戏') pr ...

  5. [HTML5实现人工智能]小游戏《井字棋》发布,据说IQ上200才能赢

    一,什么是TicTacToe(井字棋)   本 游戏 为在下用lufylegend开发的第二款小游戏.此游戏是大家想必大家小时候都玩过,因为玩它很简单,只需要一张草稿纸和一只笔就能开始游戏,所以广受儿 ...

  6. 『HTML5实现人工智能』小游戏《井字棋》发布,据说IQ上200才能赢【算法&代码讲解+资源打包下载】

    一,什么是TicTacToe(井字棋) 本游戏为在下用lufylegend开发的第二款小游戏.此游戏是大家想必大家小时候都玩过,因为玩它很简单,只需要一张草稿纸和一只笔就能开始游戏,所以广受儿童欢迎. ...

  7. Java井字棋游戏

    试着写了一个井字棋游戏,希望各位能给予一些宝贵的建议. 一.棋盘类 package 井字棋游戏; public class ChessBoard { private int number; Perso ...

  8. 井字棋小游戏(C语言)

    最近沉迷于<NetHack>.<DCSS>等字符游戏,对其很感兴趣,于是用C语言写了个字符界面的井字棋小游戏.欢迎大家指教. 编写时遇到了一些问题,我原先准备用循环,直到读取到 ...

  9. 程序设计入门—Java语言 第五周编程题 2井字棋(5分)

    2 井字棋(5分) 题目内容: 嗯,就是视频里说的那个井字棋.视频里说了它的基本思路,现在,需要你把它全部实现出来啦. 你的程序先要读入一个整数n,范围是[3,100],这表示井字棋棋盘的边长.比如n ...

随机推荐

  1. sql server判断表存在

    在创建表.更改表结构.删除表或对表进行什么操作之前,一个比较严谨的做法是先判断该表是否已经存在. 在SQL Server中判断一个表是否存在,有两个方法,下面以diso表为例. 方法1 from sy ...

  2. Oracle数据库之第一篇

    1 : Oracle 简介 : 是美国ORACLE公司(甲骨文)提供的以分布式数据库为核心的一组软件产品,是目前最流行的客户/服务器IP,端口,用户名.密码,点击:连接 (CLIENT/SERVER) ...

  3. 【Visio流程图】借助redis来实现数据即时刷新

    [需求:]数据从竞品网站爬过来,经过分析处理之后,把结果通过网页实时反馈给业务人员. [应用:]2个应用: 一个是爬取数据的应用:不断从竞品网站爬数据,每次爬到的数据为一批.然后,对每一批爬到的数据进 ...

  4. Mac进行Flutter的相关开发配置

    参考链接:https://www.cnblogs.com/tangtianming/p/10797227.html

  5. 【Swift】WKWebView与JS的交互使用

    一.前言 近日,有朋友问我关于WKWebView与JS的交互问题,可我之前一直使用的是UIWebView,也不曾做过WKWebView的交互啊!接下来大家一块学习下WKWebView是怎么实现原生代码 ...

  6. Android 进程间通讯方式

    Android 进程间通讯方式 1.通过单向数据管道传递数据 管道(使用PipedWriter/ 创建PipedReader)是java.io包的一部分.也就是说,它们是一般的Java功能,而不是An ...

  7. coalesce搭配nullif使用

    with t1 as ( select NUll as col1, '' as col2, 'aaa' as col3 ) --关于COALESCE用法 当col1 为 Null时候返回 col2 依 ...

  8. 如何使用块更改跟踪文件估算RMAN增量备份大小 (Doc ID 1938079.1)

    How to estimate RMAN incremental backup size using block change tracking file (Doc ID 1938079.1) APP ...

  9. go语言设计模式之proxy

    代理模式,单元测试用例真的写得详细, 受教~ proxy.go package proxy import ( //"errors" "fmt" ) type U ...

  10. OMM机制(占位)

    由于没有swap分区,导致系统启动omm机制,把mysql干掉