C语言实现三字棋
实现以下:
1游戏不退出,继续玩下一把(循环)
2应用多文件的形式完成
test.c. --测试游戏
game.c -游戏函数的实现
game.h -游戏函数的声明
(2)游戏再走的过程中要进行数据的存储,可以使用3*3的二维数组
char bord[3][3];
(2)没下棋之前数组中存放空格
以下都是具体函数的实现,都在game.c文件中完成,test.c调用,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] =' ';}}
}
第二步打印棋盘
//版本1
// void DisplayBoard(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++)
// {
// printf("%c",board[i][j]);
// }
// printf("\n");
// }
// }//版本2
// void DisplayBoard(char board[ROW][COL],int row,int col)
// {
// int i = 0;
// for(i = 0;i<row;i++)
// {
// //1.打印数据
// printf("%c | %c | %c \n",board[i][0],board[i][1],board[i][2]);
// //打印分割线
// if(i < row -1)
// {
// printf("---|---|---");
// }
// // int j = 0;
// // for(j = 0; j<col;j++)
// // {
// // printf("%c",board[i][j]);
// // }
// // printf("\n");
// }
// }//版本3
//打印棋盘
void DisplayBoard(char board[ROW][COL],int row,int col)
{int i = 0;for(i = 0;i<row;i++){//1.打印数据int j = 0;for(j = 0; j < col;j++){printf(" %c ",board[i][j]);if(j < col - 1){printf("|");}}printf("\n");//打印分割线if(i < row -1){//printf("---|---|---");int j = 0;for(j = 0; j < col;j++){printf("---");if(j < col - 1){printf("|");}}printf("\n");} }
}
第三步玩家开始下棋
//玩家下棋
void PlayerMove(char board[ROW][COL],int row,int col)
{int x = 0;int y = 0;printf("玩家下棋:>\n");while (1){printf("请输入下棋的坐标,中间使用空格>:");scanf("%d %d",&x,&y);//坐标合法if(x >= 1 && x <= row && y >= 1 && y <= col){if(board[x-1][y-1] == ' ') //可以落子{board[x - 1][y - 1] = '*';break;} else //不能落子{printf("坐标被占用,不能落子,请重新输入坐标\n");}} else //非法{printf("坐标非法,重新输入\n");}}}
第四步电脑下棋
//电脑随机下棋,随机生成坐标
void ComputerMove(char board[ROW][COL],int row,int col)
{int x = 0; // 0~row-1int y = 0; // 0~col-1printf("电脑下棋:>\n");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)
{//赢int i = 0;//判断行是否三个相等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];}}//判断列是否三个相等for(i = 0;i < col; i++){if(board[0][i] == board[1][i] && board[1][i] == board[2][i] && board[0][i] != ' '){return board[0][i];}}//判断对角线是否三个相等for(i = 0;i < col; 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(IsFull(board,row,col) == 1){return 'Q';}//继续return 'C';
}
以下是完整版内容
game.h文件
//声明函数
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define ROW 3
#define 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);//判断输赢
//玩家赢 -'*'
//电脑赢- '#'
//平局 -'Q'
//继续游戏 -'C'
char IsWin(char board[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] =' ';}}
}
//版本1
// void DisplayBoard(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++)
// {
// printf("%c",board[i][j]);
// }
// printf("\n");
// }
// }//版本2
// void DisplayBoard(char board[ROW][COL],int row,int col)
// {
// int i = 0;
// for(i = 0;i<row;i++)
// {
// //1.打印数据
// printf("%c | %c | %c \n",board[i][0],board[i][1],board[i][2]);
// //打印分割线
// if(i < row -1)
// {
// printf("---|---|---");
// }
// // int j = 0;
// // for(j = 0; j<col;j++)
// // {
// // printf("%c",board[i][j]);
// // }
// // printf("\n");
// }
// }//版本3
//打印棋盘
void DisplayBoard(char board[ROW][COL],int row,int col)
{int i = 0;for(i = 0;i<row;i++){//1.打印数据int j = 0;for(j = 0; j < col;j++){printf(" %c ",board[i][j]);if(j < col - 1){printf("|");}}printf("\n");//打印分割线if(i < row -1){//printf("---|---|---");int j = 0;for(j = 0; j < col;j++){printf("---");if(j < col - 1){printf("|");}}printf("\n");} }
}//玩家下棋
void PlayerMove(char board[ROW][COL],int row,int col)
{int x = 0;int y = 0;printf("玩家下棋:>\n");while (1){printf("请输入下棋的坐标,中间使用空格>:");scanf("%d %d",&x,&y);//坐标合法if(x >= 1 && x <= row && y >= 1 && y <= col){if(board[x-1][y-1] == ' ') //可以落子{board[x - 1][y - 1] = '*';break;} else //不能落子{printf("坐标被占用,不能落子,请重新输入坐标\n");}} else //非法{printf("坐标非法,重新输入\n");}}}//电脑随机下棋,随机生成坐标
void ComputerMove(char board[ROW][COL],int row,int col)
{int x = 0; // 0~row-1int y = 0; // 0~col-1printf("电脑下棋:>\n");while (1){x = rand() % row;y = rand() % col;if(board[x][y] == ' '){board[x][y] = '#';break;}}}int IsFull(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] == ' '){return 0;}}}return 1;
}//判断输赢
char IsWin(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][0] != ' '){return board[i][0];}}//判断列是否三个相等for(i = 0;i < col; i++){if(board[0][i] == board[1][i] && board[1][i] == board[2][i] && board[0][i] != ' '){return board[0][i];}}//判断对角线是否三个相等for(i = 0;i < col; 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(IsFull(board,row,col) == 1){return 'Q';}//继续return 'C';
}
test.c文件
#include "game.h"void menu()
{printf("**********************\n");printf("***** 1.play ******\n");printf("***** 0.eixt ******\n");printf("**********************\n");
}void game()
{char board[ROW][COL] = {0};InitBoard(board,ROW,COL);//打印棋盘DisplayBoard(board,ROW,COL);//下棋char ret = 0;while (1){//玩家下棋PlayerMove(board, ROW, COL);//打印棋盘DisplayBoard(board,ROW,COL);//判断输赢ret = IsWin(board,ROW,COL);if(ret != 'C'){break;}//电脑下棋ComputerMove(board, ROW, COL); //打印棋盘DisplayBoard(board,ROW,COL);//判断输赢ret = IsWin(board,ROW,COL);if(ret != 'C'){break;}}if (ret == '*'){printf("玩家赢\n");} else if(ret == '#'){printf("电脑赢\n");} else{printf("平局\n");}}
int main()
{int input = 0;srand((unsigned int) time(NULL));do{menu();printf("请选择:>");scanf("%d",&input);switch (input){case 1:printf("三字棋游戏\n");game();break;case 0:printf("退出游戏\n");break;default:printf("选择错误,重新选择!\n");break;}} while (input);return 0;
}
相关文章:
C语言实现三字棋
实现以下: 1游戏不退出,继续玩下一把(循环) 2应用多文件的形式完成 test.c. --测试游戏 game.c -游戏函数的实现 game.h -游戏函数的声明 (2)游戏再走的过程中要进行数据的存储,可以使用3*3的二维数组 char bor…...
【LeetCode】35.复杂链表的复制
题目 请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个 next 指针指向下一个节点,还有一个 random 指针指向链表中的任意节点或者 null。 示例 1: 输入:head [[7,null],[13,0],[11,4]…...
代码大全阅读随笔(五)
数据初始化要点: 数据初始化过程很容易出错,所以请使用本章介绍的方法,来初始化数据,从而避免由于非预期的初始化值而造成的错误。 最小化变量作用域。 使用相同的变量的语句尽可能的集中在一起。 早期绑定会减少灵活性࿰…...
No1.详解【2023年全国大学生数学建模竞赛】C题——蔬菜类商品的自动定价与补货决策(代码 + 详细输出 + 数据集代码 下载)
时间告诉你什么叫衰老,回忆告诉你什么叫幼稚。不要总在过去的回忆里纠缠,昨天的太阳,晒不干今天的衣裳。 🎯作者主页: 追光者♂🔥 🌸个人简介: 💖[1] 计算机专业硕士研究生💖 🌿[2] 2023年城市之星领跑者TOP1(哈尔滨)🌿 🌟[3] 2022年度博客…...
有什么好用的电容笔?apple pencil替代品推荐
近年来,电容笔越来越成为人们日常生活中常见的数码产品之一。电容笔的便捷性得到了消费者的认可。它逐渐取代无纸化书写。那么到底电容笔哪个品牌好呢,电容笔哪一款最好用呢,今天小编给大家总结几款市面好用的电容笔,让我们一起来…...
什么是回调函数?写出一个示例?
聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ 回调函数⭐ 示例⭐ 写在最后 ⭐ 专栏简介 前端入门之旅:探索Web开发的奇妙世界 记得点击上方或者右侧链接订阅本专栏哦 几何带你启航前端之旅 欢迎来到前端入门之旅!这个专栏是为那些对Web开发感兴趣、刚刚踏入前…...
深度学习在医疗保健领域的应用:从图像识别到疾病预测
文章目录 深度学习在医学影像识别中的应用1. 癌症检测2. 病理学图像分析3. 医学图像分割 深度学习在疾病预测中的应用1. 疾病风险预测2. 疾病诊断辅助3. 药物研发 深度学习在个性化治疗中的应用1. 基因组学分析2. 临床数据集成 深度学习在医疗保健中的挑战和未来数据隐私和安全…...
SpringBoot实现自定义environment中的value加密
environment中的value为什么要加密? 未经过加密的配置文件,密码均是采用明文密码,很容易导致信息泄露。 SpringBoot environment中的value加密代码如下 package com.xxx.core.encryption;import com.google.common.collect.Maps; import lomb…...
celery的用法--任务调度
在Celery中,任务(Task)是执行特定操作的基本单元。任务可以异步执行,可以带有参数,可以返回结果,可以链式调用,还可以设置任务优先级、超时等属性。 1.定义任务: 使用app.task装饰器…...
MyBatis-Plus学习笔记总结
一、查询 构造器分为QueryWrapper和LambdaQueryWrapper 创建实体类User package com.system.mybatisplus.model;import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.annotation.TableField; import com.baomidou.mybatisplus.annotation.…...
How Language Model Hallucinations Can Snowball
本文是LLM系列文章,针对《How Language Model Hallucinations Can Snowball》的翻译。 语言模型幻觉是如何产生雪球的 摘要1 引言2 为什么我们期待幻觉像滚雪球一样越滚越大?3 实验4 我们能防止雪球幻觉吗?5 相关工作6 结论局限性 摘要 在实…...
autojs修改顶部标题栏颜色
顶部标题栏的名字是statusBarColor 不是toolbar。难怪我搜索半天搜不到 修改之后变成这样了 代码如下: "ui"; importClass(android.view.View); importClass(android.graphics.Color); ui.statusBarColor(Color.parseColor("#ffffff")); ui.…...
arppy gis 读取text 并批量添加字段 arcpy.AddField_management
arppy gis 读取text 并批量添加字段 arcpy.AddField_management 例:给“省级行政区域”添加“A、B、C、D” 4个字段。 (1)用Excel制作出字段及其描述表,定义字段结构; (2)复制除标题行以为的内…...
Pandas中at、iat函数详解
前言 嗨喽,大家好呀~这里是爱看美女的茜茜呐 at 函数:通过行名和列名来取值(取行名为a, 列名为A的值) iat 函数:通过行号和列号来取值(取第1行,第1列的值) 本文给出at、iat常见的…...
【Spring Boot】JPA — JPA入门
JPA简介 1. JPA是什么 JPA是Sun官方提出的Java持久化规范,它为Java开发人员提供了一种对象/关联映射工具来管理Java应用中的关系数据,通过注解或者XML描述“对象-关系表”之间的映射关系,并将实体对象持久化到数据库中,极大地简…...
c#反射(Reflection)
当我们在C#中使用反射时,可以动态地获取和操作程序集、类型和成员。下面是一个简单的C#反射示例,展示了如何使用反射来调用一个类的方法: using System; using System.Reflection;public class MyClass {public void MyMethod(){Console.Wri…...
Lua 元表和元方法
一、元表 元表可以修改一个值在面对一个未知操作时的行为,Lua 中使用 table 作为元表的承载。 元表只能给出预先定义的操作集合的行为,比类会更加受限制,不支持继承。 Lua 每一个值都可以有元表 : 表和用户数据类型都具有各自…...
【Git】01-Git基础
文章目录 Git基础1. 简述1.1 版本管理演变1.2 Git的特点 2. Git安装2.1 安装文档2.1 配置user信息 3. 创建仓库3.1 场景3.2 暂存区和工作区 4. 重命名5. 常用git log版本历史5.1 查看当前分支日志5.2 简洁查看日志5.3 查看最近指定条数的日志 6. 通过图形界面工具查看版本7. 探…...
【Vue2.0源码学习】生命周期篇-初始化阶段(initState)
文章目录 1. 前言2. initState函数分析3. 初始化props3.1 规范化数据3.2 initProps函数分析3.3 validateProp函数分析3.4 getPropDefaultValue函数分析3.5 assertProp函数分析 4. 初始化methods5. 初始化data6. 初始化computed6.1 回顾用法6.2 initComputed函数分析6.3 defineC…...
专升本英语零基础学习
1. 词法 1.1 名词 名词(n.),是词类的一种,属于实词。他表示人,物,事,地点或抽象概念的统一名称。 1.1 名词的含义 名词(n.),是词类的一种,属于实词。他表示人&#x…...
QUIC协议连接详解(二)
目录 一:RTT解释 二:QUIC 1-RTT连接 三:QUIC 0-RTT连接 一:RTT解释 在介绍QUIC协议的连接之前先科普一下什么是RTT。RTT是Round-Trip Time的英文缩写,翻译过来就是一趟来回的时间即往返时延。时间计算即从发送方发送…...
JAVA 经常遇到一些问题【第二部分36~51】
重拾者: 每日记录至目前(记录51种不同场景的问题可参考解决方案) 异常就两部分: 1、excepiton信息: 报错产生的原因 2、at开头表示: 异常产生的代码位置。 欢迎关注本人微信公众号:AIM…...
蓝桥杯打卡Day6
文章目录 N的阶乘基本算术整数查询 一、N的阶乘OI链接 本题思路:本题是关于高精度的模板题。 #pragma GCC optimize(3) #include <bits/stdc.h>constexpr int N1010;std::vector<int> a; std::vector<int> f[N];std::vector<int> mul(in…...
spark集群问题汇总
一、 磁盘问题 问题描述可能原因解决措施core节点磁盘不足, 并且持续增加未开启spark-history的日志清理打开日志清理: spark.history.fs.cleaner.enabled task节点磁盘不足 APP应用使用磁盘过大: 1. 严重的数据倾斜 2. 应用本身数据量大 1. 解决数据倾斜 2. 加大资源, 增加e…...
WebServer 解析HTTP 请求报文
一、TCP 状态转换 浏览器访问网址,TCP传输全过程 二、TCP协议的通信过程 三、TCP 通信流程 // TCP 通信的流程 // 服务器端 (被动接受连接的角色) 1. 创建一个用于监听的套接字- 监听:监听有客户端的连接- 套接字:这…...
Golang开发--interface的使用
在Go语言中,接口(interface)是一种特殊的类型,它定义了一组方法的集合。接口为实现多态性提供了一种机制,允许不同的数据类型实现相同的方法,从而可以以统一的方式处理这些不同类型的对象。接口在Go中广泛用…...
2023 年高教社杯全国大学生数学建模竞赛题目 B 题 多波束测线问题
B 题 多波束测线问题 单波束测深是利用声波在水中的传播特性来测量水体深度的技术。声波在均匀介质中作匀速直线传播,在不同界面上产生反射,利用这一原理,从测量船换能器垂直向海底发射声波信号,并记录从声波发射到信号接收的传播…...
leetcode算法题--生成特殊数字的最少操作
原题链接:https://leetcode.cn/problems/minimum-operations-to-make-a-special-number/description/ 感觉还是比较难想到的。。 func minimumOperations(num string) int {res : len(num)if strings.Contains(num, "0") {res-- }f : func(tail string)…...
数学建模--决策树的预测模型的Python实现
目录 1.算法流程简介 2.算法核心代码 3.算法效果展示 1.算法流程简介 """ 决策树的应用:对泰坦尼克号数据集成员进行预测生死 算法流程还是比较简单的,简单学习一下决策树跟着注释写即可 文章参考:https://zhuanlan.zhihu.com/p/133838427 算法种遇上sklear…...
Linkstech多核并行仿真丨光伏发电系统模型及IEEE 39 bus模型多核并行实测
新能源场站和区域电网作为复杂且具有动态特性的大规模电力系统,需要实时仿真测试来验证其性能、稳定性和响应能力。在这种背景下,多核并行仿真运算显得尤为重要。多核并行仿真能够同时处理电力系统的复杂模型,加速仿真过程,实现接…...
哪些网站可以找到做海报的素材/百度导航最新版本免费下载
写在前面 是这样的,我们现在接口使用了Ocelot做网关,Ocelot里面集成了基于IdentityServer4开发的授权中心用于对Api资源的保护。问题来了,我们的Api用了SwaggerUI做接口的自文档,那就蛋疼了,你接入了IdentityServer4的…...
免费微信网站制作/营业推广的方式
软件开发工程师(JAVA) 岗位职责: 1、 负责京东核心业务系统的需求分析、设计、开发工作 2、 负责相关技术文档编写工作 3、 解决系统中的关键问题和技术难题 任职要求: 1. 踏实诚恳、责任心强,能接受较大的工作强度,具备良好的沟…...
淘宝网站策划怎么做/网络服务器配置与管理
出题:定义一个复杂链表:在单向链表的基础上,每个节点附加一个指向链表中其他任意节点的指针sibling,实现CNode* Clone(Cnode *head)函数复制这个复杂链表; 分析: 解法1:将head复制到CHead中&…...
盐城网站开发厂商/公司网页网站建设
Datawhale干货 作者:[美]霍布森莱恩,科尔霍华德在学习神经网络之前,我们需要对神经网络底层先做一个基本的了解。我们将在本节介绍感知机、反向传播算法以及多种梯度下降法以给大家一个全面的认识。一、感知机数字感知机的本质是从数据集中…...
网站开发公司 网站空间/业务推广方式有哪些
python统计字符的个数代码实例 python统计不同字符的个数 首先使用input获取输入数据,并存入到str参数里 然后使用for循环str的每一个字符,循环内使用str.count()获取字符出现的字数,并存入一个字典中 最后输出字典即可。 代码如下࿱…...
不同类型网站比较及网站域名设计/app下载
文章目录KVM的vCPU调度算法的原理O(N)调度器O(1)调度器CFS调度器Xen Credit算法的原理CFS算法与Credit算法比较算法实现虚拟机兼容性实时性参考资料KVM的vCPU调度算法的原理 KVM的vCPU的整个生命周期都在Qemu线程的上下文中,在Kernel(root模式ÿ…...