三子棋游戏思路

article/2025/7/10 21:57:09

今天用C语言来模拟一个三子棋游戏。

总共大概分为五部

1.构建一个菜单出来,让玩家可以选择是否进行游戏。

2.打印棋盘,通过对二维数组的运用,打印一个N*N的棋盘,主要是用空格将棋盘初始化,并将棋盘的框架打出。

3.玩家进行下棋,玩家会随意的在空格出下棋。这里需要注意的玩家并不知道二维数组的每行每列是从0开始的,并且玩家不能输入超出棋盘的棋子或者在已经下过的位置继续输入。

4.电脑进行下棋,电脑下棋要注意随机性,这里就引用rand函数(需要srand函数当作前提条件)和time函数。电脑下棋相比玩家下棋就简单一些,可以用while循环让电脑自己下到不是重复的位置。

5.判断输赢,总共只有玩家赢,电脑赢和平局三种情况。写出代码判断谁先连成一条线即可,否则就是棋盘下满了还未分出胜负则为平局。


首先,先将代码的基本构建写出来,先来构建一个菜单:

#include<stdio.h>
void menu()   //构建的菜单 
{
    printf("********************************\n");
    printf("************  1.play  **********\n");
    printf("************  2.exit  **********\n");
    printf("********************************\n");
}
void test()    //玩家的选择
{
    int input = 0;
    do
    {
        menu();
        printf("请选择是否游玩游戏");
        scanf("%d", &input);
        switch (input)
        {
        case 1:
            printf("玩游戏\n");
            break;
        case 2:
            printf("退出游戏\n");
            break;
        default:
            printf("选择错误,请重新选择\n");
            break;
        }

    } while (input);
}
int main()
{
    test();
    return 0;
}

编译代码,大概是这个结果:

 

接下来,我们就要写case 1中的玩游戏的过程了,这里我们创建一个game()的函数来实现:

void game()
{
    char board[ROW][COL] = { 0 };           //存放下棋的数据
    InitBoard(board, ROW, COL);             //存放下棋的数据
    DisplayBoard(board, ROW, COL);      //打印棋盘

先打印一个棋盘的模型:

 

这里的函数很多,所以我们创建了一个game.h的头文件和一个game.c的源文件去实现这些函数。

game.h:

#include<stdio.h>
#define ROW 3
#define COL 3
//初始化棋盘
void InitBoard(char board[ROW][COL], int row, int col);
//打印棋盘
void DisplayBoard(char borad[ROW][COL], int row, int col);

game.c:

要让我们的棋盘中没有数字,将我们的二维数组都赋值为空格

#include"game.h"
void InitBoard(char board[ROW][COL], int row, int col)
{
    int i = 0;
    for (i = 0; i < row; i++)
    {
        int j = 0;
        for (j = 0; j < col; j++)
        {
            board[i][j] = ' ';
        }
    }
}

下面的代码每次打印一个数据,打印一个竖线 一行打印完之后换行打印横线。就是除了数据元素,再就是打印棋盘的结构,让我们的棋盘能显现出来。

void DisplayBoard(char borad[ROW][COL], int row, int col)
{
    int i = 0;
    for (i = 0; i < row; i++)
    {
        int j = 0;
        for (j = 0; j < col; j++)
        {
            printf(" %c ", borad[i][j]);
            if (j < col - 1)
            {
                printf("|");
            }
        }
        printf("\n");
        if (i < row - 1)
        {
            for (j = 0; j < col; j++)
            {
                printf("---");
                if (j < col - 1)
                    printf("|");
            }
            printf("\n");
        }


    }
}

然后,就是我们的玩家下棋:

void game()
{
    //玩家下棋
    Player_Move(board, ROW, COL);
    DisplayBoard(board, ROW, COL);
}

 

game.h:

//玩家下棋
void Player_Move(char board[ROW][COL], int row, int col);

game.c:

void Player_Move(char board[ROW][COL], int row, int col)
{
    int a = 0;
    int b = 0;
    printf("玩家下棋\n");
        while (1)
        {
            printf("请玩家输入坐标:");
            scanf("%d %d", &a, &b);
            if(a >= 1 && a <= row && b >= 1 && b <= col)
            {
                //开始下棋
                if (board[a - 1][b - 1] == ' ')        //这里是因为玩家不知道二维数组的每行每列是0开始的
                {
                    board[a - 1][b - 1] = '*';
                    break;
                }
                else
                {
                   printf("该坐标已被占用,请重新输入坐标\n");
                }
            }
            else
            {
               printf("坐标输入非法,请重新输入\n");
            }
        }
}

接下来,来实现电脑下棋:

void game()
{
    //电脑下棋
    computer_move(board, ROW, COL);//随机下棋
    DisplayBoard(board, ROW, COL);
}

game.h: 

//电脑下棋
void computer_move(char board[ROW][COL], int row, int col);

game.c:

void computer_move(char board[ROW][COL], int row, int col)
{
        int x = 0;
        int y = 0;
        printf("电脑下棋\n");
        while (1)
        {
        x = rand() % row;
        y = rand() % col;
        if (board[x][y] == ' ')
        {
            board[x][y]='#';
            break;
        }
    }
}

最后,就是判断输赢:

这里要看在什么情况下,游戏就结束了。

1.玩家赢,返回'*'

2.电脑赢,返回'#'

3.平局,返回'Q'

如果都没赢,那就继续,返回'C'

while (1)
    {
        //玩家下棋
        Player_Move(board, ROW, COL);
        DisplayBoard(board, ROW, COL);
        //判断输赢
        ret = is_win(board, ROW, COL);       //新创建的函数
        if (ret != 'c')
        {
            break;
        }
        //电脑下棋
        computer_move(board, ROW, COL);//随机下棋
        DisplayBoard(board, ROW, COL);
        ret = is_win(board, ROW, COL);
        if (ret != 'c')
        {
            break;
        }
    }
    if (ret == '*')
    {
        printf("玩家赢了\n");
    }
    else if (ret == '#')
    {
        printf("电脑赢了\n");
    }
    else
    {
        printf("平局\n");
    }
}

game.h:

//判断输赢
char is_win(char board[ROW][COL], int row, int col);game.c

game.c:

char is_win(char board[ROW][COL], int row, int col)
{
//判断行
    int i = 0;
    for (i = 0; i < row; i++)
    {
        if (board[i][0] == board[i][1] && board[i][1] == board[i][2] && board[i][1] != ' ')
        {
            return board[i][1];
        }
    }
    //判断列
    for (i = 0; i < col; i++)
    {
        if (board[0][i] == board[1][i] && board[1][i] == board[2][i] && board[1][i] != ' ')
        {
            return board[1][i];
        }
    }
    //对角线
    if (board[0][0] == board[1][1] && board[1][1] == board[2][2] && board[1][1] != ' ')
    {
        return board[1][1];
    }
    if (board[0][2] == board[1][1] && board[1][1] == board[2][0] && board[1][1] != ' ')
    {
        return board[1][1];
    }

    //判断平局
    if (is_full(board, row, col) == 1)       //这里我们还创建了一个函数来判断棋盘是否下满
    {
        return 'Q';
    }
    //继续
    return 'C';

 }

下面仍在game.c里面实现上面if_full()的函数,因为我只需要放在当前源文件,不让其他文件使用,这里就可以用static来修饰。

static int is_full(char board[ROW][COL], int row, int col)
{
    int i = 0;
    for (i = 0; i < row; i++)
    {
        int j = 0;
        for (j = 0; j < col; j++)
        {
            if (board[i][j] == ' ')     //如果棋盘内有空的,则返回0;
            {
                return 0;
            }
        }
    }
        return 1;
}


http://chatgpt.dhexx.cn/article/5pXc8QSV.shtml

相关文章

【C语言】三子棋游戏详解

目录 一、三子棋的游戏规则 二、基本流程 三、实现步骤 3.1打印菜单 3.2 创建并初始化棋盘 3.3 打印棋盘 3.4 玩家落子 3.5 电脑落子 3.6 判断输赢 四、游戏演示 五、完整代码 一、三子棋的游戏规则 三子棋也就是经常玩的井字棋&#xff0c;游戏分为双方对战&#xff…

JAVA安卓植物大战僵尸主题四子棋游戏

前言 这里使用安卓最基本的API实现双人四子棋游戏&#xff08;无AI&#xff09;&#xff0c;开发语言为java&#xff0c;开发环境为Android Studio 2.1.2&#xff0c;目标SDK版本为24&#xff0c;最低为15&#xff1b;界面采用植物大战僵尸主题&#xff0c;图片资源来源于网络&…

三子棋游戏

目录 一、三子棋游戏简介 二、三子棋游戏创建文件 三、三子棋游戏设计 1.主菜单的创建 2.棋盘设计 四、三子棋游戏结果 五、代码源 一、三子棋游戏简介 三子棋是黑白棋的一种。三子棋是一种民间传统游戏&#xff0c;又叫九宫棋、圈圈叉叉、一条龙、井字棋等。将正方形对角线…

人机对战初体验—四子棋游戏

一、实验介绍 1.1 实验内容 实验利用Python模拟AI和玩家进行四子棋游戏&#xff0c;利用游戏实验Pygame库&#xff0c;为游戏提供界面和操作支持。AI算法借用蒙特卡洛搜索树思想。通过设置AI的难度系数&#xff0c;即AI所能考虑到的未来棋子的可能走向&#xff0c;从而选择出最…

Pygame——AI重力四子棋

突然奇想&#xff0c;什么时候可以自己实现一个机器对战的小游戏&#xff0c;但一直不敢去尝试&#xff0c;直到偶尔发现了重力四子棋的规则&#xff0c;有限的空间棋盘正好可以拿来练手。 有关下棋AI的算法&#xff0c;说来说去也就那么几种&#xff0c;随机蒙特卡罗方法、UC…

C语言简单游戏编程入门之四子棋

运行截图 源代码 #include<stdio.h> #include<stdlib.h> /*四子棋1.在一个6行7列的棋盘中2.玩家1和玩家2依次交替下子3.每次下子落于棋盘可能达到的最下方4.先四子相连为胜5.棋盘已满且无四子相连为平局 *//*定义常量*/ //行数 #define ROW 7 //列数 #define C…

基于Python实现四子棋游戏

1. 实验介绍 1.1 实验内容 实验利用 Python 模拟 AI 和玩家进行四子棋游戏&#xff0c;利用游戏实验 Pygame 库&#xff0c;为游戏提供界面和操作支持。AI 算法借用蒙特卡洛搜索树思想。通过设置 AI 的难度系数&#xff0c;即 AI 所能考虑到的未来棋子的可能走向&#xff0c;…

运用Python——劳拉下棋_四连环游戏_重力四子棋游戏(代码与游戏判定)

导航 运用Python——爬虫_网易云音乐热评 运用Python——游戏_四子棋_劳拉下棋 文章目录 导航1.游戏规则2.玩法分析3.部分详解第一部分&#xff1a;初始化第二部分&#xff1a;棋盘显示第三部分&#xff1a;玩家输入第四部分&#xff1a;运行第五部分&#xff1a;胜利判断 4.完…

ISME | 热液微生物群落揭示了喷口区的生物地理学和嗜热性的进化历史

Auka热液喷口区的微生物群落揭示了喷口区的生物地理学和嗜热性的进化历史 Microbial community of recently discovered Auka vent field sheds light on vent biogeography and evolutionary history of thermophily Article The ISME Journal, [IF 10.3] DOI&#xff1a;10.…

S32K1xx 固件更新

1 介绍 随着当前技术的进步&#xff0c;车辆变得更加电子化而不是机械化。车辆中的电子创新不断增加。因此&#xff0c;车辆中的软件也在增加&#xff0c;因此存在潜在错误的风险。 每次发现软件错误时&#xff0c;都需要进行召回过程来更新软件。这些召回代表了汽车制造商的…

萤火虫算法综述

1.萤火虫算法概述 萤火虫闪烁的光芒在热带和温带地区的夏季天空中是一道令人惊叹的风景。大约有两千种萤火虫&#xff0c;大多数萤火虫会发出短暂而有节奏的闪光。闪光的模式对于特定物种来说往往是独一无二的。闪光是由生物发光过程产生的&#xff0c;这种信号系统的真正功能仍…

《闪》(霹雳战狗 bolt)电影感悟

when you stuck your head, relax, turn and pull. 有时候做人做事要转换一下方式&#xff0c;否则还是会卡住头。Because all around the planet, there are animals who feel like they cannot, like a little hamster, who once spends his day in the vehicle park dreamin…

大学英语四新视野 课后习题+答案翻译 Unit1~Unit8

Unit 1 Text A: Words in use 2022年6月16日 20:57 1 As the gender barriers crumbled, the number of women working as lawyers, doctors, or bankers began to increase significantly from the mid-20th century. 随着性别障碍的消除&#xff0c;从20世纪中期开始&am…

拉勾网爬虫

源代码&#xff1a;https://github.com/carlblocking/xxw-for-public/tree/master/LaGouSpider 前几天写了一个知乎网的爬虫并爬取了一些数据&#xff0c;然而新鲜感消失的很快。于是&#xff0c;大概2天前开始试着爬取拉勾网上的数据。 在解析数据的过程中&#xff0c;知乎爬…

爬虫实战(三) 用Python爬取拉勾网

0、前言 最近博主面临着选方向的困难&#xff08;唉&#xff0c;选择困难症患者 &#xff1e;﹏&#xff1c;&#xff09;&#xff0c;所以希望了解一下目前不同岗位的就业前景 这时&#xff0c;就不妨写个小爬虫&#xff0c;爬取一下 拉勾网 的职位数据&#xff0c;并用图形…

python爬取拉勾网公司信息(您操作太频繁,请稍后访问)

最近爬取拉勾网上的公司信息碰到了很多问题&#xff0c;但是都一一解决了。作为一个招聘网站&#xff0c;他的反爬措施做的还是很好的。 为了调查招聘网站上有多少公司&#xff0c;以及公司信息&#xff0c;并把公司信息存入MongoDB数据库中。 先上运行成功代码&#xff1a; …

2022年爬取拉勾网详情页面地址信息

众所周知&#xff0c;拉勾网的反爬机制一直做的很好&#xff0c;前些年还可以通过找到网页源代码找到岗位详情页面的地址&#xff0c;而现在拉勾网的详情页面地址直接没了&#xff0c;这就很奇怪&#xff0c;那么鼠标点击他又是如何跳转到别的页面 点开源代码中&#xff0c;每一…

django+拉勾网招聘数据可视化

django拉勾网招聘数据可视化&#xff0c;此系统有详细的录屏&#xff0c;下面只是部门截图&#xff0c;需要看完整录屏联系博主 系统开发语言python&#xff0c;框架为django&#xff0c;数据库mysql&#xff0c;分为爬虫和可视化分析

Python爬虫实战:爬取拉勾网并对其进行数据分析

###整体的 思路 是采用 selenium 模拟浏览器的行为&#xff0c;具体的步骤如下&#xff1a; 初始化爬取数据&#xff0c;这里分为两个部分&#xff1a;一是爬取网页数据&#xff0c;二是进行翻页操作保存数据&#xff0c;将数据保存到文件中数据可视化 ###整体的 代码结构 如…

什么你还不知道招聘信息,小唐来教你——最新2021爬取拉勾网招聘信息(二)

文章目录 前言一、准备我们的库二、数据清洗三、核密度图及词云制作四、完整代码五、扩展 上一篇&#xff1a;什么你还不知道招聘信息&#xff0c;小唐来教你——最新2021爬取拉勾网招聘信息&#xff08;一&#xff09; 下一篇&#xff1a;没有拉&#xff01; 前言 既然我们上…