三子棋

简介: 关于c语言设计的三子棋小游戏

@TOC

前言

所有代码详解 都在代码中

1. test.c---内容框架

#include"game.h"
void menu()
{
    printf("********************\n");
    printf("***1.play 0.exit****\n");
    printf("********************\n");
}
void game()
{
    char ret = 0;
    char board[row][col] = { 0 };
    initboard(board, row, col);//初始化棋盘
    displayboard(board, row, col);//打印棋盘
    while (1)//使用while才可以把玩家和电脑下棋的过程多次进行
    {
        pepplayer( board,  row,  col);//玩家
        ret = iswin(board, row, col);//iswin用来判断是谁赢
        if (ret != 'c')//c代表继续  如果ret的值不为继续 就跳出循环
        {
            break;
        }
        displayboard(board, row, col);
        complayer( board,  row, col);//电脑
        ret = iswin(board, row, col);
        if (ret != 'c')
        {
            break;
        }
        displayboard(board, row, col);
    }
    if (ret == '*')
    {
        printf("玩家赢\n");
    }
    else if (ret == '#')
    {
        printf("电脑赢\n");
    }
    else
    {
        printf("平局\n");
    }
}
int main()
{
    int input = 0;
    do
    {
        menu();
        printf("输入数字:>");
        scanf("%d", &input);
        switch (input)
        {
        case 1:
            game();
            break;
        case 0:
            printf("输入错误\n");
            break;
        default:
            break;
        }
    } while (input);
    return 0;
}

2. game .h---函数的声明和头文件

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#define col 3//代表行
#define row 3//代表列
void initboard(char board[row][col], int rows, int cols);//这里参数本想都为 row 和col但是常量不能作为参数
void displayboard(char board[row][col], int rows, int cols);
void pepplayer(char board[row][col], int rows, int cols);
void complayer(char board[row][col], int rows, int cols);
char iswin(char board[row][col], int rows, int cols);//判断谁赢

3. game .c--函数的定义

#include"game.h"
void initboard(char board[row][col], int rows, int cols)//初始化
{
    int i = 0;
    int j = 0;
    for (i = 0; i < rows; i++)
    {
        for (j = 0; j < cols; j++)
        {
            board[i][j] = ' ';//将每个都赋值成 空格  如果赋值 0会报错
        }
    }
}
void displayboard(char board[row][col], int rows, int cols)//打印
{
    int i = 0;
    int j = 0;
    for (i = 0; i < rows; i++)
    {
        for (j = 0; j < cols; j++)
        {
            printf("%c ", board[i][j]);//先打印出空格
            if (j < cols - 1)//最后一列没有|
            {
                printf(" |");//然后再打印 | 这里需要加一个空格 否则会发现与后面的|连接不上
            }
        }
        printf("\n");//换行
        if (i < rows - 1)//因为最后一行不需要---
        {
            for (j = 0; j < rows; j++)
            {
                printf("---");
                if (j < row - 1)//最后一列没有|
                {
                    printf("|");
                }
            }
        }
        printf("\n");//这里还需要空格 
    }
}
void pepplayer(char board[row][col], int rows, int cols)
{
    int x = 0;
    int y = 0;
    while (1)
    {
        printf("请输入坐标:>");//因为要多次调用所以放在里面
        scanf("%d%d", &x, &y);
        if (x >= 1 && x <= rows && y >= 1 && y <= cols)//范围
        {
            if (board[x - 1][y - 1] == ' ')//输入的是从1开始的值  而数组下标是值-1
            {
                board[x - 1][y - 1] = '*';//*代表玩家
                break;
            }
            else
            {
                printf("坐标被占用\n");
            }
        }
        else
        {
            printf("坐标非法\n");
        }
    }
}
void complayer(char board[row][col], int rows, int cols)
{
    while (1)
    {
        int x = rand() % row;//使用rand()%3 返回0到2
        int y = rand() % col;
            if (board[x][y] == ' ')
            {
                board[x][y] = '#';//这里本身就从0开始所以不需要-1
                break;
            }
    }
}
int isfull(char board[row][col], int rows, int cols)//判断棋盘是否满 若满了返回 1
{
    int i = 0;
    int j = 0;
    for (i = 0; i < rows; i++)
    {
        for (j = 0; j < cols; j++)
        {
            if (board[i][j] == ' ')
            {
                return 0;
            }
        }
    }
    return 1;
}
char iswin(char board[row][col], int rows, int cols)
{
    int i = 0;
    for (i = 0; i < col; i++)//每一列的情况
    {
        if (board[0][i] == board[1][i] && board[1][i] == board[2][i] && board[1][i] != ' ')//若每一列相等时
        {
            return board[0][i]; //返回一个值 就知道是 '*' / '#'
        }
    }
    for (i = 0; i< row; i++)//每一行的情况
    {
        if (board[i][0] == board[i][1] && board[i][1] == board[i][2] && board[i][0] != ' ')//若每一行相等时
        {
            return board[i][0];//返回一个值 就知道是 '*' / '#'
        }
    }
    if (board[0][0] == board[1][1] && board[1][1] == board[2][2] && board[0][0] != ' ')
    {
        return board[0][0];//对角线
    }
    if (board[0][2] == board[1][1] && board[1][1] == board[2][0] && board[0][2] != ' ')
    {
        return board[0][2];
    }
    if (isfull(board, row, col) == 1)//棋盘满了
    {
        return 'Q';
    }
    else
    return 'c';//以上情况都没发生 即棋盘继续执行
}
目录
相关文章
|
9天前
|
数据采集 人工智能 安全
|
4天前
|
机器学习/深度学习 人工智能 前端开发
构建AI智能体:七十、小树成林,聚沙成塔:随机森林与大模型的协同进化
随机森林是一种基于决策树的集成学习算法,通过构建多棵决策树并结合它们的预测结果来提高准确性和稳定性。其核心思想包括两个随机性:Bootstrap采样(每棵树使用不同的训练子集)和特征随机选择(每棵树分裂时只考虑部分特征)。这种方法能有效处理大规模高维数据,避免过拟合,并评估特征重要性。随机森林的超参数如树的数量、最大深度等可通过网格搜索优化。该算法兼具强大预测能力和工程化优势,是机器学习中的常用基础模型。
307 164
|
3天前
|
机器学习/深度学习 自然语言处理 机器人
阿里云百炼大模型赋能|打造企业级电话智能体与智能呼叫中心完整方案
畅信达基于阿里云百炼大模型推出MVB2000V5智能呼叫中心方案,融合LLM与MRCP+WebSocket技术,实现语音识别率超95%、低延迟交互。通过电话智能体与座席助手协同,自动化处理80%咨询,降本增效显著,适配金融、电商、医疗等多行业场景。
318 155
|
12天前
|
SQL 自然语言处理 调度
Agent Skills 的一次工程实践
**本文采用 Agent Skills 实现整体智能体**,开发框架采用 AgentScope,模型使用 **qwen3-max**。Agent Skills 是 Anthropic 新推出的一种有别于mcp server的一种开发方式,用于为 AI **引入可共享的专业技能**。经验封装到**可发现、可复用的能力单元**中,每个技能以文件夹形式存在,包含特定任务的指导性说明(SKILL.md 文件)、脚本代码和资源等 。大模型可以根据需要动态加载这些技能,从而扩展自身的功能。目前不少国内外的一些框架也开始支持此种的开发方式,详细介绍如下。
873 6
|
5天前
|
机器学习/深度学习 人工智能 前端开发
构建AI智能体:六十九、Bootstrap采样在大模型评估中的应用:从置信区间到模型稳定性
Bootstrap采样是一种通过有放回重抽样来评估模型性能的统计方法。它通过从原始数据集中随机抽取样本形成多个Bootstrap数据集,计算统计量(如均值、标准差)的分布,适用于小样本和非参数场景。该方法能估计标准误、构建置信区间,并量化模型不确定性,但对计算资源要求较高。Bootstrap特别适合评估大模型的泛化能力和稳定性,在集成学习、假设检验等领域也有广泛应用。与传统方法相比,Bootstrap不依赖分布假设,在非正态数据中表现更稳健。
260 113

热门文章

最新文章