C语言—————三子棋游戏

标签: C语言

三子棋游戏

问题描述
3*3的棋盘中,只要一条线上出现三个一样的棋子就获胜(玩家或电脑);如果棋盘已经放满还未出现三个棋子一条线则打成平手。
具体细节

  1. 初始化棋盘(用空格初始化)
//初始化棋盘
void initChess(char chessbox[ROW][COL]){
	for (int row = 0; row < ROW; row++){
		for (int col = 0; col < COL; col++){
			chessbox[row][col] = ' ';
		}
	}
}
  1. 打印棋盘
//打印棋盘
void printChess(char chessbox[ROW][COL]){
	system("cls");
	printf("+---+---+---+\n");
	for (int row = 0; row < ROW; row++){
		printf("| %c | %c | %c |\n", 
			chessbox[row][0], chessbox[row][1],
			chessbox[row][2]);
		printf("+---+---+---+\n");
	}
}
  1. 电脑落子(用o表示电脑落子)
//电脑落子(用o表示)
void computerMove(char chessbox[ROW][COL]){
	srand(time(0));
	while (1){
		int row = rand() % 3;
		int col = rand() % 3;
		if (chessbox[row][col] == ' '){
			chessbox[row][col] = 'o';
			break;
		}

	}
}
  1. 玩家落子
//玩家落子(用x表示)
void playerMove(char chessbox[ROW][COL]){
	int row, col;
	while (1){
		printf("请输入您的落子地点:");
		scanf("%d %d", &row, &col);
		if (row >= 3 || col >= 3){
			printf("您输入的落子位置有误,请重新输入:");
			continue;
		}
		if (chessbox[row][col] == ' '){
			chessbox[row][col] = 'x';
			break;
		}
		printf("该位置已有棋子,请重新输入:");
	}
}
  1. 三个棋子一条线
  • 在一行或一列实现三个棋子一条线
//行
	for (int row = 0; row < ROW; row++){
		if (chessbox[row][0] != ' '
			&&chessbox[row][0] == chessbox[row][1]
			&& chessbox[row][0] == chessbox[row][2]){
			return chessbox[row][0];
		}
	}
	//列
	for (int col = 0; col < COL; col++){
		if (chessbox[0][col] != ' '
			&&chessbox[0][col] == chessbox[1][col]
			&& chessbox[0][col] == chessbox[2][col]){
			return chessbox[0][col];
		}
	}
  • 对角线实现三个棋子一条线
if (chessbox[0][0] != ' '
		&&chessbox[0][0] == chessbox[1][1]
		&& chessbox[0][0] == chessbox[2][2]){
		return chessbox[0][0];
	}
	if (chessbox[2][0] != ' '
		&&chessbox[2][0] == chessbox[1][1]
		&& chessbox[2][0] == chessbox[0][2]){
		return chessbox[2][0];
	}
  1. 和棋
  • 棋盘放满还未获胜,则为和棋,打成了平手。
在这里插入代码片
	//和棋				
	if(isFull(checkbox)){
		return 'a';
		}					
	
  1. 输赢约定:
  • 返回x代表玩家获胜
if (isWinner(chessbox) == 'x'){
			printf("恭喜您赢啦!\n");
			break;
		}
  • 返回o代表电脑获胜
if (isWinner(chessbox) == 'o'){
			printf("很遗憾,您输了!\n");
			break;
		}
  • 返回a代表和棋(打成平手)
if (isWinner(chessbox) == 'a'){
			printf("你和电脑同一水平呦!\n");
			break;
		}
  1. 判断棋盘是否放满:
  • 返回1代表棋盘已满
  • 返回0代表棋盘未满
//判断棋盘是否摆满
//1表示满;0表示不满。
int isFullChess(char chessbox[ROW][COL]){
	for (int row = 0; row < ROW; row++){
		for (int col = 0; col < COL; col++){
			//找到空格,说明未满
			if (chessbox[row][col] == ' '){
				return 0;
			}
		}
	}
	return 1;
}

源代码:

#define  _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#define ROW 3
#define COL 3
//玩家落子(用x表示)
void playerMove(char chessbox[ROW][COL]){
	int row, col;
	while (1){
		printf("请输入您的落子地点:");
		scanf("%d %d", &row, &col);
		if (row >= 3 || col >= 3){
			printf("您输入的落子位置有误,请重新输入:");
			continue;
		}
		if (chessbox[row][col] == ' '){
			chessbox[row][col] = 'x';
			break;
		}
		printf("该位置已有棋子,请重新输入:");
	}
}
//电脑落子(用o表示)
void computerMove(char chessbox[ROW][COL]){
	srand(time(0));
	while (1){
		int row = rand() % 3;
		int col = rand() % 3;
		if (chessbox[row][col] == ' '){
			chessbox[row][col] = 'o';
			break;
		}

	}
}
//初始化棋盘
void initChess(char chessbox[ROW][COL]){
	for (int row = 0; row < ROW; row++){
		for (int col = 0; col < COL; col++){
			chessbox[row][col] = ' ';
		}
	}
}
//打印棋盘
void printChess(char chessbox[ROW][COL]){
	system("cls");
	printf("+---+---+---+\n");
	for (int row = 0; row < ROW; row++){
		printf("| %c | %c | %c |\n", 
			chessbox[row][0], chessbox[row][1],
			chessbox[row][2]);
		printf("+---+---+---+\n");
	}
}
//判断棋盘是否摆满,摆满返回1;未满返回0
int isFullChess(char chessbox[ROW][COL]){
	for (int row = 0; row < ROW; row++){
		for (int col = 0; col < COL; col++){
			//找到空格,说明未满
			if (chessbox[row][col] == ' '){
				return 0;
			}
		}
	}
	return 1;
}
//约定:返回x代表玩家赢了;返回o代表电脑赢了;返回a代表和棋
char isWinner(char chessbox[ROW][COL]){
	//行
	for (int row = 0; row < ROW; row++){
		if (chessbox[row][0] != ' '
			&&chessbox[row][0] == chessbox[row][1]
			&& chessbox[row][0] == chessbox[row][2]){
			return chessbox[row][0];
		}
	}
	//列
	for (int col = 0; col < COL; col++){
		if (chessbox[0][col] != ' '
			&&chessbox[0][col] == chessbox[1][col]
			&& chessbox[0][col] == chessbox[2][col]){
			return chessbox[0][col];
		}
	}
	//对角线
	if (chessbox[0][0] != ' '
		&&chessbox[0][0] == chessbox[1][1]
		&& chessbox[0][0] == chessbox[2][2]){
		return chessbox[0][0];
	}
	if (chessbox[2][0] != ' '
		&&chessbox[2][0] == chessbox[1][1]
		&& chessbox[2][0] == chessbox[0][2]){
		return chessbox[2][0];
	}
	//和棋
	if (isFullChess(chessbox)){
		return 'a';
	}
	return 0;
}
//开始一局游戏
void game(){

	char chessbox[ROW][COL] = { 0 };
	initChess(chessbox);
	printf("游戏开始啦!\n");
	printChess(chessbox);
	while (1){
		//玩家落子
		playerMove(chessbox);
		//打印棋牌
		printChess(chessbox);
		//判断胜负
		if (isWinner(chessbox) == 'x'){
			printf("恭喜您赢啦!\n");
			break;
		}
		if (isWinner(chessbox) == 'a'){
			printf("你和电脑同一水平呦!\n");
			break;
		}
		//电脑落子
		computerMove(chessbox);
		//打印棋牌
		printChess(chessbox);
		//判断胜负
		if (isWinner(chessbox) == 'o'){
			printf("很遗憾,您输了!\n");
			break;
		}
		if (isWinner(chessbox) == 'a'){
			printf("你和电脑同一水平呦!\n");
			break;
		}
	}
}
int menu(){
	printf("===============\n");
	printf("1.开始游戏\n");
	printf("0.结束游戏\n");
	printf("===============\n");
	int choice;
	printf("请输入您的选择:");
	scanf("%d", &choice);
	return choice;
}

int main()
{

ile (1){
		int choice=menu();
		if (choice == 1){
			game();
			continue;
		}
		else if (choice == 0){
			break;
		}else{
			printf("输入有误,请您重新输入!\n");
			continue;
		}
	}
	system("pause");
	return 0;
}

运行结果:

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

版权声明:本文为m0_50527451原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/m0_50527451/article/details/109503673

智能推荐

前端小练习:jQuery酷炫照片墙

jQuery酷炫照片墙 效果展示: HTML代码: css代码: jQuery代码: 方法 解释 transform transform 属性向元素应用 2D 或 3D 转换。该属性允许我们对元素进行旋转、缩放、移动或倾斜。W3scool Math.random() 产生随机数。编程狮 translate 绘图函数编程狮 attr attr() 方法设置或返回被选元素的属性和值。编程狮 anima...

springMVC拦截器

一、     SpringMVC拦截器实现原理 用户请求到DispatherServlet中,DispatherServlet调用HandlerMapping查找Handler,HandlerMapping返回一个拦截器链(HandlerExecutionChain),springmvc中的拦截器是通过HandlerMapping发起的。 &nbs...

Unity Json反序列化

Json反序列化 结果:...

[机器学习-回归算法]Sklearn之线性回归实战

Sklearn之线性回归实战 一,前言 二,热身例子 三,贸易公司的简单例子 四,Sklearn 官网里的一个例子 参考资料 一,前言 一元线性回归的理论片请看我这个链接 二,热身例子 预测直线 y=1x1+2x2+3y = 1x_1 + 2x_2 +3y=1x1​+2x2​+3 导入LinearRegression 从Sklearn.liear_model 包里 拟合数据也可以说是训练 检验正确...

Android 开发者,你真的懂 Context 吗?

Android Context 详解 前言 一、Context是什么 二、Context结构 1、ContextImpl类介绍 2、ContextWrapper类介绍 3、ContextThemeWrapper 三、Context的数量 四、Context注意事项 五、如何正确回复以上面试题? 前言 Context 相信所有的 Android 开发人员基本上每天都在接触,因为它太常见了。但是这并不...

猜你喜欢

SpringMVC ----Json的简单交互处理

SpringMVC--Json Json的介绍 什么是JSON? JSON 和 JavaScript 对象互转 Controller返回JSON数据 Jackson 乱码 乱码的解决方法一 代码优化 乱码统一解决方法 返回json字符串统一解决 测试多个对象的集合输出 输出时间对象 抽取为工具类 FastJson fastjson 三个主要的类: JSONObject JSONArray JSON...

微信小程序自定义组件简单实现

本文将教你如何实现一个自定义的toast提示框,实现后的基本效果图如下: 小程序中一个自定义组件由 json wxml wxss js 4个文件组成的。下面我们一步一步地来创建文件及完成其中的配置: step1:创建自定义组件 首先创建一个components文件夹,用于放置所有自定义的组件,创建之后的目录结构为 其中的toastedit是我们本次...

PyTorch学习(四)--用PyTorch实现线性回归

教程视频:https://www.bilibili.com/video/BV1tE411s7QT 废话不多说,代码如下: 结果: 0 56.52023696899414 1 25.170454025268555 2 11.214292526245117 3 5.001270771026611 4 2.2352840900421143 5 1.0038176774978638 6 0.4554775...

1、Qt 的窗口组件和窗口类型

1、窗口组件 图形用户界面由不同的窗口和窗口组件组成 组件的类型 — 容器类(父组件):用于包含其它的界面组件 — 功能类(子组件):用于实现特定的交互功能 Qt 中没有父组件的顶级组件叫做窗口 QWidget QWidget 继承于 QObject 和 QPaintDevice — QObject 是所有支持 Qt 对象模型的基类 — QPaint...

从APP跳转到微信指定联系人聊天页面功能的实现与采坑之旅

从APP跳转到微信指定联系人聊天页面功能的实现与采坑之旅 起因 实现逻辑 效果图 实现过程 跳转微信按钮点击事件 无障碍监听主要方法 一些必要的参数 监听主要方法 遇到的坑 1. 搜索内容无法赋值给搜索框 2. 如何停止监听? 3. 没查询到结果如何停止监听? 4. 如果在微信其他页面怎么办? 5. 页面改变UI加载太慢 6. 聊天界面和主页面是同一个活动 7. 搜索不到结果时,发现他在搜索结果页...