C语言实现简单的三子棋

 更新时间:2020年11月11日 08:42:18   作者:一颗苹果.  
这篇文章主要为大家详细介绍了C语言实现简单的三子棋,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言实现简单三子棋游戏的具体代码,供大家参考,具体内容如下

一、主要思想

1、创建一个3*3的棋盘(使用字符数组)
2、初始化棋盘(用空格填充)
3、打印棋盘(使其有可见的边框)
4、玩家落子,用x表示(检验是否越界,是否已经落子,是否赢)
5、电脑落子,用o表示(检验是否已经落子,是否赢)  注:电脑在有效范围内随机落子,使用当前时间戳设置随机种子即srand(time(0))
6、三种情况:玩家赢,电脑赢,和棋

二、代码实现

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
//定义宏,棋盘的最大行数和最大列数为3
#define MAX_ROW 3
#define MAX_COL 3
 
//无论是玩家落子还是电脑落子,都需确定落子的行和列,以此确定在棋盘上的位置
 
//玩家落子
//玩家输入之后,需要检验是否输入越界,该位置是否已经落子
//若无这两种情况,就将该位置赋值为'x',否则重新输入
char playermove(char chessboard[MAX_ROW][MAX_COL])
{
 int row = 0;
 int col = 0;
 while (1){
 printf("请输入您落子的位置:(row col)");
 scanf("%d %d", &row, &col);
 //校验
 //校验输入是否输入有误
 if (row < 0 || row >= MAX_ROW || col<0 || col>=MAX_COL){
 printf("您的输入越界!!\n");
 continue;
 }else if (chessboard[row][col]!=' '){
 printf("该位置已落子!!\n");
 continue;
 }else{
 chessboard[row][col] = 'x';
 return chessboard[row][col];
 }
 
 }
}
 
//电脑落子
//需要检验该位置是否落子(无需检验是否越界,因为我们设置的落子范围为有效范围)
//若无以上情况,就将该位置赋值为'o',否则,重新获取随机值
void computermove(char chessboard[MAX_ROW][MAX_COL])
{
 while (1){
 int row = rand() % MAX_ROW;   //获取一个0~2范围内的随机行数
 int col = rand() % MAX_COL;   //获取一个0~2范围内的随机列数
 //校验落子位置是否已经落子
 if (chessboard[row][col] != ' '){
 continue;
 }
 chessboard[row][col] = 'o';
 break;
 }
 
}
 
//判断是否为和棋,即判断棋盘是否满
//找到空格代表未满,找不到,则满了(因为我们初始化的时候将棋盘初始化为空格' ')
//满返回1,未满返回0
char isFull(char chessboard[MAX_ROW][MAX_COL])
{
 for (int row = 0; row < MAX_ROW; row++){
 for (int col = 0; col < MAX_COL; col++){
 //找到空格
 if (chessboard[row][col] == ' '){
 return 0;
 }
 }
 }
 //未找到,即满了
 return 1;
}
 
//判断是否赢
//'x'表示玩家获胜
//'o'表示电脑获胜
//' '表示胜负未分
//'h'表示和棋
char isWin(char chessboard[MAX_ROW][MAX_COL])
{
//同一行相同
//注意:相同应排除空格相同的情况,以下同
 for (int row = 0; row < MAX_ROW; row++){
 if (chessboard[row][0]!=' '
 &&(chessboard[row][0] ==chessboard[row][1])
 &&(chessboard[row][0]== chessboard[row][2])){
 return chessboard[row][0];
 }
 }
//同一列相同
 for (int col = 0; col < MAX_COL; col++){
 if (chessboard[0][col]!=' '
 &&(chessboard[0][col] == chessboard[1][col])
 &&(chessboard[0][col] == chessboard[2][col])){
 return chessboard[0][col];
 }
 }
//对角线相同
 if (chessboard[0][0] != ' '
 && (chessboard[0][0] == chessboard[1][1])
 && (chessboard[0][0] == chessboard[2][2])){
 return chessboard[0][0];
 }
 if (chessboard[0][2] != ' ' 
 &&(chessboard[0][2] == chessboard[1][1])
 &&(chessboard[0][2] == chessboard[2][0])){
 return chessboard[0][2];
 }
//和棋
 if (isFull(chessboard)){
 return 'h';
 }
 return ' ';
}
 
//初始化棋盘,初始化为空格' '
void init(char chessboard[MAX_ROW][MAX_COL])
{
 for (int row = 0; row < MAX_ROW; row++){
 for (int col = 0; col < MAX_COL; col++){
 chessboard[row][col] = ' ';
 }
 }
}
//打印棋盘
void printchessboard(char chessboard[MAX_ROW][MAX_COL])
{
 printf("+---+---+---+\n");
 for (int row = 0; row < MAX_ROW; row++){
 printf("| %c | %c | %c |\n", chessboard[row][0], chessboard[row][1], chessboard[row][2]);
 printf("+---+---+---+\n");
 }
 
}
 
//游戏
void game()
{
 char chessboard[MAX_ROW][MAX_COL] = {0};
 init(chessboard);//初始化棋盘
 char winner = ' ';
 while (1){
 printchessboard(chessboard);//打印棋盘
 playermove(chessboard);//玩家落子
 //校验,是否赢是否和棋
 winner = isWin(chessboard);
 if (winner != ' '){
 break;
 }
 computermove(chessboard);//电脑落子
 winner = isWin(chessboard);
 if (winner != ' '){
 break;
 }
 }
 if (winner == 'x'){
 printchessboard(chessboard);
 printf("恭喜您赢了!\n");
 }else if (winner == 'o'){
 printchessboard(chessboard);
 printf("很遗憾您输了!\n");
 }else if (winner == 'h'){
 printchessboard(chessboard);
 printf("和棋!您和电脑棋技相当~\n");
 }
}
 
//菜单
int menue(int choice)
{
 printf("************************\n");
 printf("1.开始游戏\n");
 printf("0.结束游戏\n");
 printf("************************\n");
 printf("请输入您的选择:");
 scanf("%d", &choice);
 return choice;
}
 
//主函数
int main()
{
 srand(time(0));
 int choice = 0;
 while (1){
 choice=menue(choice);
 if (choice == 1){
 game();
 }else if (choice == 0){
 break;
 }else{
 printf("您的输入有误,请重新输入\n");
 continue;
 }
 }
 system("pause");
 return 0;
}

三、运行结果

大概框架如此,也可以进行优化,比如system("cls")清屏等

更多有趣的经典小游戏实现专题,分享给大家:

C++经典小游戏汇总

python经典小游戏汇总

python俄罗斯方块游戏集合

JavaScript经典游戏 玩不停

java经典小游戏汇总

javascript经典小游戏汇总

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

相关文章

  • C语言 小游戏打砖块实现流程详解

    C语言 小游戏打砖块实现流程详解

    打砖块游戏是一种动作电子游戏的名称。玩家操作一根萤幕上水平的“棒子”,让一颗不断弹来弹去的“球”在撞击作为过关目标消去的“砖块”的途中不会落到萤幕底下。球碰到砖块、棒子与底下以外的三边会反弹,落到底下会失去一颗球,把砖块全部消去就可以破关
    2021-11-11
  • 创建二叉树 二叉树如何删除节点操作教程

    创建二叉树 二叉树如何删除节点操作教程

    本文将详细介绍二叉树的创建,节点删除,节点增加等一系列操作方法,需要的朋友可以参考下
    2012-12-12
  • Windows下Qt读取系统的内存、CPU、GPU等使用信息的示例代码

    Windows下Qt读取系统的内存、CPU、GPU等使用信息的示例代码

    在当今计算机应用广泛的领域中,了解系统的内存、CPU和GPU使用情况是非常重要的,本文将介绍如何使用Qt和Windows API来读取系统的内存、CPU和GPU使用详细信息,将提供一个完整的示例代码,需要的朋友可以参考下
    2024-01-01
  • Qt音视频开发之利用ffmpeg实现解码本地摄像头

    Qt音视频开发之利用ffmpeg实现解码本地摄像头

    一开始用ffmpeg做的是视频流的解析,后面增加了本地视频文件的支持,到后面发现ffmpeg也是支持本地摄像头设备的,所以本文就来用ffmpeg实现解码本地摄像头功能吧
    2023-03-03
  • C语言中数据如何存储进内存揭秘

    C语言中数据如何存储进内存揭秘

    使用编程语言进行编程时,需要用到各种变量来存储各种信息。变量保留的是它所存储的值的内存位置。这意味着,当您创建一个变量时,就会在内存中保留一些空间。您可能需要存储各种数据类型的信息,操作系统会根据变量的数据类型,来分配内存和决定在保留内存中存储什么
    2022-08-08
  • C++中的构造函数详解

    C++中的构造函数详解

    这篇文章主要介绍了C++ 中构造函数的实例详解的相关资料,希望通过本文能帮助到大家,让大家理解掌握这部分内容,需要的朋友可以参考下
    2021-09-09
  • 基于MFC实现多线程进度条

    基于MFC实现多线程进度条

    这篇文章主要为大家详细介绍了如何基于MFC实现多线程进度条效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2025-01-01
  • C语言实现Linux下的socket文件传输实例

    C语言实现Linux下的socket文件传输实例

    这篇文章主要介绍了C语言实现Linux下的socket文件传输的方法,较为详细的分析了C语言文件Socket文件传输客户端与服务器端相关实现技巧,需要的朋友可以参考下
    2015-06-06
  • xxx_cast类型转换的实现方法

    xxx_cast类型转换的实现方法

    下面小编就为大家带来一篇xxx_cast类型转换的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12
  • Visual Studio 2022配置fftw第三方库的详细过程

    Visual Studio 2022配置fftw第三方库的详细过程

    FFTW是一个可以进行可变长度一维或多维DFT的开源C程序库,是目前最快的FFT算法实现,本文简述了在Windows平台上,如何在C++中调用FFTW,所使用的IDE为Visual Studio 2022,感兴趣的朋友一起看看吧
    2024-06-06

最新评论