【C语言】三子棋游戏实现代码

目录

1.三子棋代码功能介绍

2.三子棋游戏实现步骤

①打印菜单栏

②判断是否进入三子棋游戏 

③三子棋游戏基本函数实现

(1)清空(初始化)棋盘函数实现

(2)打印棋盘函数实现

(3)玩家下棋函数实现 

(4)电脑下棋函数实现

(5)判断输赢函数

(6)判断平局函数

④整个游戏算法实现(实现逻辑)

3.三子棋游戏完整代码实现

①game.h头文件

②progress.c源文件

③game.c源文件

 4.结语



1.三子棋代码功能介绍

①用坐标代替点位来下棋

②与电脑进行对局

输赢的判断

2.三子棋游戏实现步骤

①打印菜单栏

void menu()//打印三子棋菜单栏
{printf("*************************\n");printf("*******THREECHESS********\n");printf("#####1.PLAY   0.EXIT#####\n");printf("*************************\n");}

②判断是否进入三子棋游戏 

通过scanf函数来获取用户输入;

再使用switch语句来判断是否进入或退出三子棋游戏;

void progress()//判断是否进入游戏
{int input = 0;do{menu();printf("请输入>:");scanf_s("%d", &input);switch (input){case 1://如果用户输入1就进入游戏printf("进入游戏\n");game();//三子棋游戏实现函数printf("\n\n\n");//打印空行使得排版更好看break;case 0:printf("退出游戏\n");break;default://输入不为1或0的情况处理printf("输入错误\n");break;}}while (input);//如果input不为0则一直进入循环判断是否进入三子棋
}

如图所示:

③三子棋游戏基本函数实现

注:首先要知道我们用二维字符数组(char board[ROW][COL])来抽象实现三子棋;

        ROW,COL宏定义为3;

        col,rol传给函数的内容也是3;

(1)清空(初始化)棋盘函数实现

初始化棋盘实际就是将二维数组的各个元素全都初始化为空格,用嵌套for循环来实现

void InitBoard(char board[ROW][COL], int row, int col)//初始化棋盘,这里ROW,COL是宏定义值是3
{int i = 0;int j = 0;for (i = 0; i < row; i++)//用for循环来逐一初始化{for (j = 0; j < col; j++){board[i][j] = ' ';//初始化为空格}}
}

(2)打印棋盘函数实现

类似于初始化棋盘函数打印棋盘函数也使用嵌套的for循环语句

并借用键盘上的字符‘|’‘-’分割棋盘形状

void DisPlayBoard(char board[ROW][COL], int row, int col)//打印棋盘,ROW,COL宏定义为3,col,
//rol传的内容也是3
{int i = 0;int j = 0;for (i = 0; i < row; i++){for (j = 0; j < col; j++)//for循环来逐一打印{printf(" %c ",board[i][j]);if (j < col - 1){printf("|");//打印‘|’来分割每个格子}	}if(i < row - 1)printf("\n---|---|---\n");//一行打印完用横线分割下一行,进行下一行的打印}
}

运行结果如下:

(3)玩家下棋函数实现 

:玩家下棋用‘*’, 电脑下棋用‘#’

        要用if语句判断玩家输入的坐标是否在3*3棋盘内;

        还要用if语句判断玩家输入的坐标是否被占用(是否已经下过)

void PlayerMove(char board[ROW][COL], int row, int col)//玩家下棋
{int x = 0;int y = 0;printf("\n玩家下棋>>");//提示玩家下棋while (1)//如果输入坐标不正确就多次输入{printf("\n请输入坐标:\n");scanf("%d%d", &x, &y);if (x > 0 && x <= row && y > 0 && y <= col)//判断坐标是否在3*3棋盘内{if (board[x - 1][y - 1] == ' ')//判断该格子是否被占用{board[x - 1][y - 1] = '*';//没有占用就放字符‘*’作为玩家下过的标志break;//玩家已经下过一次后跳出循环进行下一轮}elseprintf("该坐标已被占用,请重新输入.\n");//如果坐标被占用进行提示重新输入}elseprintf("坐标输入非法,请重新输入.\n");//如果坐标非法提示重新输入}
}

运行结果如下:

(4)电脑下棋函数实现

:使用随机数生成函数(rand)来获得电脑要下的坐标;

        获得的随机数除以3取余数就可以获得大于等于0小于3的整数以此来作为电脑下棋的坐标;

        同时也要判断随机生成的坐标是否合法

        如果坐标合法且未被占用就标记‘#’;

void ComputerMove(char board[ROW][COL], int row, int col)//电脑下棋
{printf("\n电脑下棋>>\n");//提示电脑下棋int x = 0;int y = 0;while (1)//如果坐标非法就重新输入{x = rand() % row;//使用随机数生成函数生成随机数,并除以3得余数获得0~2的数y = rand() % col;{if (board[x][y] == ' ')//判断该坐标在棋盘上是否被占用{board[x][y] = '#';//没被占用就标记‘#’break;}			}}
}

(5)判断输赢函数

:判断输赢函数多增加了一个参数tmp来传入玩家和电脑代表的字符,一旦一列或一行或从左往右或从右往左的直线有三个相同的字符并且等于tmp的就返回字符tmp,通过tmp就可以判断出玩家赢了还是电脑赢了

char IsWin(char board[ROW][COL], int row, int col, char tmp)//判断输赢,返回字符
{int i = 0;int j = 0;int count = 0;for (i = 0; i < ROW; i++)//判断一是否有三个字符相同{int count = 0;for (j = 0; j < COL; j++){if (board[i][j] != tmp)//有一个不同就break跳出本次循环break;elsecount++;//有一个相同count就+1if (count == 3)//当count等于3时就代表一行中有三个相同return tmp;//当一行中有三个相同的字符时就代表该字符所对应的赢了返回该字符}}for (j = 0; j < COL; j++)//同理判断一列中是否有三个字符相同{int count = 0;for (i = 0; i < ROW; i++){if (board[i][j] != tmp)break;elsecount++;if (count == 3)return tmp;}}for (count = 0,i = 0; i < ROW; i++)//判断从左往右的直线三个字符是否相同{if (board[i][i] != tmp)break;elsecount++;if (count == 3)return tmp;	}for (count = 0,j = COL - 1,i =0; j >= 0,i <ROW; j--,i++)//判断从左往右的直线{if (board[i][j] != tmp)break;elsecount++;if (count == 3)return tmp;}return 0;
}

(6)判断平局函数

:除了判断输赢还要记得判断是否有平局的情况;

        用嵌套for循环来逐一判断二位数组是否有空格;

        没有空格代表平局,返回字符‘Q’

char IsFull(char board[ROW][COL], int row, int col)//判断平局
{int i = 0;int j = 0;for (i = 0; i < row; i++){for (j = 0; j < col; j++)//使用for循环逐一判断棋盘是否有空格{if (board[i][j] == ' ')return 0;//有空格也就是还没下完返回0}}return 'Q';//没有空格平局了返回字符‘Q’
}

④整个游戏算法实现(实现逻辑)

void game()//游戏的整个算法实现
{char ret = 0;char bian = 0;char board[ROW][COL] = { 0 };InitBoard(board, ROW, COL);//清空棋盘DisPlayBoard(board, ROW, COL);//打印棋盘while (1){PlayerMove(board, ROW, COL);//玩家下棋DisPlayBoard(board, ROW, COL);//打印棋盘ret = IsWin(board, ROW, COL, '*');//判断输赢bian = IsFull(board, ROW, COL);//判断是否平局if (ret == '*'){printf("\n玩家赢啦~");break;}if (bian == 'Q'){printf("\n平局");break;}ComputerMove(board, ROW, COL);//电脑下棋DisPlayBoard(board, ROW, COL);//打印棋盘ret = IsWin(board, ROW, COL, '#');//判断输赢bian = IsFull(board, ROW, COL);//判断是否平局if (ret == '#'){printf("\n太可惜了,电脑赢了");break;}if (bian == 'Q'){printf("\n平局");break;}}
}

运行结果如下:

3.三子棋游戏完整代码实现

:有些注释上文标注但在完整代码中未标注

①game.h头文件

#pragma once
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<time.h>
constexpr auto ROW = 3;
constexpr auto COL = 3;
void InitBoard(char board[ROW][COL], int row, int col);//初始化棋盘函数
void DisPlayBoard(char board[ROW][COL], int row, int col);//打印棋盘函数
void PlayerMove(char board[ROW][COL], int row, int col);//玩家下棋函数
void ComputerMove(char board[ROW][COL], int row, int col);//电脑下棋函数
char IsWin(char board[ROW][COL], int row, int col, char tmp);//判断输赢函数
char IsFull(char board[ROW][COL], int row, int col);//判断平局函数

②progress.c源文件

#include"game.h"
void menu()//打印菜单栏
{printf("*************************\n");printf("*******THREECHESS********\n");printf("#####1.PLAY   0.EXIT#####\n");printf("*************************\n");}
void game()//游戏的整个算法实现
{char ret = 0;char bian = 0;char board[ROW][COL] = { 0 };InitBoard(board, ROW, COL);//清空棋盘DisPlayBoard(board, ROW, COL);//打印棋盘while (1){PlayerMove(board, ROW, COL);//玩家下棋DisPlayBoard(board, ROW, COL);//打印棋盘ret = IsWin(board, ROW, COL, '*');//判断输赢bian = IsFull(board, ROW, COL);//判断是否平局if (ret == '*'){printf("\n玩家赢啦~");break;}if (bian == 'Q'){printf("\n平局");break;}ComputerMove(board, ROW, COL);//电脑下棋DisPlayBoard(board, ROW, COL);//打印棋盘ret = IsWin(board, ROW, COL, '#');//判断输赢bian = IsFull(board, ROW, COL);//判断是否平局if (ret == '#'){printf("\n太可惜了,电脑赢了");break;}if (bian == 'Q'){printf("\n平局");break;}}
}void progress()//判断是否进入游戏
{int input = 0;do{menu();printf("请输入>:");scanf_s("%d", &input);switch (input){case 1:printf("进入游戏\n");game();printf("\n\n\n");break;case 0:printf("退出游戏\n");break;default:printf("输入错误\n");break;}}while (input);}int main()	
{int row = ROW;int col = COL;srand((unsigned int)time(NULL));//设置随机数的生成起点progress();return 0;}

③game.c源文件

#include"game.h"
void InitBoard(char board[ROW][COL], int row, int col)//初始化棋盘
{int i = 0;int j = 0;for (i = 0; i < row; i++){for (j = 0; j < col; j++){board[i][j] = ' ';}}
}
void DisPlayBoard(char board[ROW][COL], int row, int col)//打印棋盘
{int i = 0;int j = 0;for (i = 0; i < row; i++){for (j = 0; j < col; j++){printf(" %c ",board[i][j]);if (j < col - 1){printf("|");}	}if(i < row - 1)printf("\n---|---|---\n");}
}void PlayerMove(char board[ROW][COL], int row, int col)//玩家下棋
{int x = 0;int y = 0;printf("\n玩家下棋>>");while (1){printf("\n请输入坐标:\n");scanf("%d%d", &x, &y);if (x > 0 && x <= row && y > 0 && y <= col){if (board[x - 1][y - 1] == ' '){board[x - 1][y - 1] = '*';break;}elseprintf("该坐标已被占用,请重新输入.\n");}elseprintf("坐标输入非法,请重新输入.\n");}
}
void ComputerMove(char board[ROW][COL], int row, int col)//电脑下棋
{printf("\n电脑下棋>>\n");int x = 0;int y = 0;while (1){x = rand() % row;y = rand() % col;{if (board[x][y] == ' '){board[x][y] = '#';break;}			}}
}char IsWin(char board[ROW][COL], int row, int col, char tmp)//判断输赢
{int i = 0;int j = 0;int count = 0;for (i = 0; i < ROW; i++){int count = 0;for (j = 0; j < COL; j++){if (board[i][j] != tmp)break;elsecount++;if (count == 3)return tmp;}}for (j = 0; j < COL; j++){int count = 0;for (i = 0; i < ROW; i++){if (board[i][j] != tmp)break;elsecount++;if (count == 3)return tmp;}}for (count = 0,i = 0; i < ROW; i++){if (board[i][i] != tmp)break;elsecount++;if (count == 3)return tmp;	}for (count = 0,j = COL - 1,i =0; j >= 0,i <ROW; j--,i++){if (board[i][j] != tmp)break;elsecount++;if (count == 3)return tmp;}return 0;
}char IsFull(char board[ROW][COL], int row, int col)//判断平局
{int i = 0;int j = 0;for (i = 0; i < row; i++){for (j = 0; j < col; j++){if (board[i][j] == ' ')return 0;}}return 'Q';
}

 4.结语

以上就是C语言实现简单三子棋游戏完整代码以及过程实现啦,我们也可以通过三子棋的代码思考五子棋游戏的实现,以及对于随机数生成来作为电脑下棋的坐标似乎有点愚笨,我们或许可以试着写一些让电脑选择坐标更聪明一点的函数,让玩家拥有更好的游戏体验哦,希望能和大家一起学习进步。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/458259.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Nacos(1)

Nacos注册中心 主要解决问题 假如微服务被调用较多&#xff0c;为了应对更高的并发&#xff0c;进行了多实例部署 此时&#xff0c;每个微服务的实例其IP或端口不同&#xff0c;问题来了&#xff1a; 这么多实例&#xff0c;如何知道每一个实例的地址&#xff1f;http请求要…

股票K线简介

股票K线&#xff08;K-Line&#xff09;是用于表示股票价格走势的图形&#xff0c;主要由四个关键价格点组成&#xff1a;开盘价、收盘价、最高价和最低价。K线图广泛应用于股票市场技术分析中&#xff0c;它提供了丰富的信息&#xff0c;帮助分析师和投资者理解市场的行情走势…

消息队列使用的四种场景介绍

一、简介 消息队列中间件是分布式系统中重要的组件&#xff0c;主要解决应用耦合&#xff0c;异步消息&#xff0c;流量削锋等问题。 实现高性能&#xff0c;高可用&#xff0c;可伸缩和最终一致性架构。 使用较多的消息队列有ActiveMQ&#xff0c;RabbitMQ&#xff0c;ZeroMQ…

go消息队列RabbitMQ - 订阅模式-fanout

1、发布订阅 订阅模式&#xff0c;消息被路由投递给多个队列&#xff0c;一个消息被多个消费者获取。 1&#xff09; 可以有多个消费者 2&#xff09; 每个消费者有自己的queue&#xff08;队列&#xff09; 3&#xff09; 每个队列都要绑定到Exchange&#xff08;交换机&…

龙测科技荣获2023年度技术生态构建奖

本月&#xff0c;由极客传媒举办的“有被Q到”2024 InfoQ 极客传媒合作伙伴年会顺利举办&#xff0c;龙测科技喜获2023年度技术生态构建奖。 InfoQ是首批将Node.js、HTML5、Docker等技术全面引入中国的技术媒体之一&#xff0c;秉承“扎根社区、服务社区、引领社区”的理念&…

2641. 二叉树的堂兄弟节点 II - 力扣(LeetCode)

题目描述 给你一棵二叉树的根 root &#xff0c;请你将每个节点的值替换成该节点的所有 堂兄弟节点值的和 。 如果两个节点在树中有相同的深度且它们的父节点不同&#xff0c;那么它们互为 堂兄弟 。 请你返回修改值之后&#xff0c;树的根 root 。 注意&#xff0c;一个节…

【RL】Bellman Equation (贝尔曼等式)

Lecture2: Bellman Equation State value 考虑grid-world的单步过程&#xff1a; S t → A t R t 1 , S t 1 S_t \xrightarrow[]{A_t} R_{t 1}, S_{t 1} St​At​ ​Rt1​,St1​ t t t, t 1 t 1 t1&#xff1a;时间戳 S t S_t St​&#xff1a;时间 t t t时所处的sta…

机器人工具箱学习(一)

一、机器人工具箱介绍 机器人工具箱是由来自昆士兰科技大学的教授Peter Corke开发的&#xff0c;被广泛用于机器人进行仿真&#xff08;主要是串联机器人&#xff09;。该工具箱支持机器人一些基本算法的功能&#xff0c;例如三维坐标中的方向表示&#xff0c;运动学、动力学模…

CentOS7搭建Hadoop集群

准备工作 1、准备三台虚拟机&#xff0c;参考&#xff1a;CentOS7集群环境搭建&#xff08;3台&#xff09;-CSDN博客 2、配置虚拟机之间免密登录&#xff0c;参考&#xff1a;CentOS7集群配置免密登录-CSDN博客 3、虚拟机分别安装jdk&#xff0c;参考&#xff1a;CentOS7集…

Android14音频进阶:MediaPlayerService如何启动AudioTrack 下篇(五十六)

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏:多媒体系统工程师系列【原创干货持续更新中……】🚀 人生格言: 人生从来没有捷径,只…

机器学习-线性回归法

线性回归算法 解决回归问题思想简单&#xff0c;实现容易许多强大的非线性模型的基础结果具有很好的可解释性蕴含机器学习中的很多重要思想 样本特征只有一个&#xff0c;称为&#xff1a;简单线性回归 通过分析问题&#xff0c;确定问题的损失函数或者效用函数 通过最优化…

Halcon机器视觉实战----提取水平方向缝隙区域

前言 如何从一块区域内找到水平方向的缝隙区域&#xff08;不是高斯线条&#xff0c;从图像中提取&#xff0c;而是从区域内提取&#xff0c;考虑到了区域所在的方向&#xff09;&#xff1b; dev_close_window () dev_open_window (0, 0, 800, 800, black, WindowHandle) re…