Java 小游戏 - 井字棋 v1.0 (初步完成) (2018.4.16更新)
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更新)的更多相关文章
- Pascal小游戏 井字棋
一个很经典的井字棋游戏 Pascal源码Chaobs奉上 注意:1.有的FP版本不支持汉语,将会出现乱码.2.别想赢电脑了,平手不错了. 井字过三关: program TicTacToe; uses ...
- C++小游戏——井字棋
#include<cstdio> #include<windows.h> #include<ctime> int main() { srand(time(NULL) ...
- Java实现简单井字棋
Java第一次实验,老师让做一个井字棋,电脑随机下棋. 然后就想能不能聪明一点,可以判断出走哪一步棋:然后只能做到不会输,还是不够聪明,只能呆板地堵住用户,smartRobot的第三个判断逻辑找不到最 ...
- python 游戏(井字棋)
1. 游戏思路和流程图 实现功能,现实生活中的井字棋玩法 游戏流程图 2. 使用模块和游戏提示 import random def game_info(): print('欢迎来到井字棋游戏') pr ...
- [HTML5实现人工智能]小游戏《井字棋》发布,据说IQ上200才能赢
一,什么是TicTacToe(井字棋) 本 游戏 为在下用lufylegend开发的第二款小游戏.此游戏是大家想必大家小时候都玩过,因为玩它很简单,只需要一张草稿纸和一只笔就能开始游戏,所以广受儿 ...
- 『HTML5实现人工智能』小游戏《井字棋》发布,据说IQ上200才能赢【算法&代码讲解+资源打包下载】
一,什么是TicTacToe(井字棋) 本游戏为在下用lufylegend开发的第二款小游戏.此游戏是大家想必大家小时候都玩过,因为玩它很简单,只需要一张草稿纸和一只笔就能开始游戏,所以广受儿童欢迎. ...
- Java井字棋游戏
试着写了一个井字棋游戏,希望各位能给予一些宝贵的建议. 一.棋盘类 package 井字棋游戏; public class ChessBoard { private int number; Perso ...
- 井字棋小游戏(C语言)
最近沉迷于<NetHack>.<DCSS>等字符游戏,对其很感兴趣,于是用C语言写了个字符界面的井字棋小游戏.欢迎大家指教. 编写时遇到了一些问题,我原先准备用循环,直到读取到 ...
- 程序设计入门—Java语言 第五周编程题 2井字棋(5分)
2 井字棋(5分) 题目内容: 嗯,就是视频里说的那个井字棋.视频里说了它的基本思路,现在,需要你把它全部实现出来啦. 你的程序先要读入一个整数n,范围是[3,100],这表示井字棋棋盘的边长.比如n ...
随机推荐
- sql server判断表存在
在创建表.更改表结构.删除表或对表进行什么操作之前,一个比较严谨的做法是先判断该表是否已经存在. 在SQL Server中判断一个表是否存在,有两个方法,下面以diso表为例. 方法1 from sy ...
- Oracle数据库之第一篇
1 : Oracle 简介 : 是美国ORACLE公司(甲骨文)提供的以分布式数据库为核心的一组软件产品,是目前最流行的客户/服务器IP,端口,用户名.密码,点击:连接 (CLIENT/SERVER) ...
- 【Visio流程图】借助redis来实现数据即时刷新
[需求:]数据从竞品网站爬过来,经过分析处理之后,把结果通过网页实时反馈给业务人员. [应用:]2个应用: 一个是爬取数据的应用:不断从竞品网站爬数据,每次爬到的数据为一批.然后,对每一批爬到的数据进 ...
- Mac进行Flutter的相关开发配置
参考链接:https://www.cnblogs.com/tangtianming/p/10797227.html
- 【Swift】WKWebView与JS的交互使用
一.前言 近日,有朋友问我关于WKWebView与JS的交互问题,可我之前一直使用的是UIWebView,也不曾做过WKWebView的交互啊!接下来大家一块学习下WKWebView是怎么实现原生代码 ...
- Android 进程间通讯方式
Android 进程间通讯方式 1.通过单向数据管道传递数据 管道(使用PipedWriter/ 创建PipedReader)是java.io包的一部分.也就是说,它们是一般的Java功能,而不是An ...
- coalesce搭配nullif使用
with t1 as ( select NUll as col1, '' as col2, 'aaa' as col3 ) --关于COALESCE用法 当col1 为 Null时候返回 col2 依 ...
- 如何使用块更改跟踪文件估算RMAN增量备份大小 (Doc ID 1938079.1)
How to estimate RMAN incremental backup size using block change tracking file (Doc ID 1938079.1) APP ...
- go语言设计模式之proxy
代理模式,单元测试用例真的写得详细, 受教~ proxy.go package proxy import ( //"errors" "fmt" ) type U ...
- OMM机制(占位)
由于没有swap分区,导致系统启动omm机制,把mysql干掉