扫雷游戏(C语言详解)
扫雷游戏(C语言详解)
- 放在最前面的
- 1、前言(扫雷游戏的简介)
- 2、扫雷游戏的规则(简易版)
- 3、代码实现
- (3.1)提醒一下:
- ( i ) 提醒1:
- ( ii ) 提醒2:
- (3.2) 上代码
- **game.h** 头文件
- **game.c** 头文件
- **test.c** 头文件
- 4、结果展示
- (4.1)输入的坐标是非法的(即不在坐标的范围)
- (4.2)输入的坐标是雷,则游戏提前结束
- (4.3)输入的坐标 不是雷,打印四周(八个坐标)有几个雷
- (4.4)成功避免所有布置的雷,游戏完美结束
- 5、END
放在最前面的
🎈 🎈 我的CSDN主页:OTWOL的主页,欢迎!!!👋🏼👋🏼
🎉🎉我的C语言初阶合集:C语言初阶合集,希望能帮到你!!!😍 😍
👋🏼🎉🎊创作不易,欢迎大家留言、点赞加收藏!!! 🥳😁😍

1、前言(扫雷游戏的简介)
《扫雷》中玩家的目标是在最短时间内识别出所有非雷区的格子,同时避免触碰到地雷。
游戏区域由多个隐藏格子组成,每个格子可能隐藏着地雷或数字,数字表示周围八个格子中地雷的数量。
玩家通过点击格子揭示内容,使用逻辑推理逐步排除雷区。
游戏考验玩家的观察力和推理能力,任何一次误点地雷都会导致游戏失败。
2、扫雷游戏的规则(简易版)
1. 第一次点击不会是雷。
2. 格子里的数字表示它周围有几个雷。
3. 游戏目标是找出所有雷,如果 “触雷” 则输。
3、代码实现
(3.1)提醒一下:
( i ) 提醒1:
我在代码注释中对每一行代码进行了 详细的 解释,保证 0基础小白能看得懂!
( ii ) 提醒2:
我写了三个文件,分别是
game.h、 game.c、test.c。
game.h里面存放着与game相关函数的声明 的 头文件。
game.c里面存放着与扫雷游戏有关的函数的实现即定义
如:初始化函数 Init()函数、布置雷 set_mine函数等 的 源文件。
test.c里面存放着 主函数(main)和 测试运行整个扫雷游戏的代码块的头文件。
(3.2) 上代码
game.h 头文件
//标准输出输出调用的头文件
#include<stdio.h>
// rand 函数 和 srand 函数调用的头文件
#include<stdlib.h>
// time()时间戳函数调用的头文件
#include<time.h>//定义一个宏定义常量 ROW 数值是 9
#define ROW 9
//定义一个宏定义常量 COL 数值是 9
#define COL 9
//定义一个宏定义常量 ROWS 数值是 9+2 = 11
#define ROWS ROW+2
//定义一个宏定义常量 COLS 数值是 9+2 = 11
#define COLS COL+2
定义一个宏定义常量 NUM(用作存储 放置雷的个数) 数值是 76
#define NUM 76//初始化函数 Init() 的声明
void Init(char board[ROWS][COLS], int rows, int cols, char set);
//打印函数 Print() 的声明
void Print(char board[ROWS][COLS], int row, int col);
//布置雷 set_mine() 的声明
void set_mine(char mine[ROWS][COLS], int row, int col);
//排雷 clear_mine() 的声明
void clear_mine(char mine[ROWS][COLS], char show[ROWS][COLS] , int row, int col);
game.c 头文件
#define _CRT_SECURE_NO_WARNINGS 1#include"game.h"//引用 game.h 头文件//初始化扫雷棋盘函数 Init() 的调用
void Init(char board[ROWS][COLS], int rows, int cols, char set)
{// 定义一个整型变量 i,// 并且初始化为 0int i = 0;//外层 for 循环for (i = 0; i < rows; i++){// 定义一个整型变量 j,// 并且初始化为 0int j = 0;//内层 for 循环for (j = 0; j < cols; j++){//将字符set的值,赋值给 board[i][j]board[i][j] = set;}}}//打印函数 Print() 的定义
void Print(char board[ROWS][COLS], int row, int col)
{// 定义一个整型变量 i,// 并且初始化为 0int i = 0;//输出打印 提示信息printf("\n------扫雷游戏------\n");// 定义一个整型变量 j,// 并且初始化为 0int j = 0;//for 循环 //用于 输出列数for (j = 0; j <= col; j++){//打印列数printf("%d列\t", j);}//换行printf("\n");//外层 for 循环for (i = 1; i <= row; i++){//打印行数printf("%d行\t", i);//内层 for 循环for (j = 1; j <= col; j++){//输出打印 board[i][j] 对应的内容// \t 是转义字符,含义是 制表符//并按照%c\t的格式 进行打印printf("%c\t", board[i][j]);}//换行printf("\n");}//输出打印 提示信息printf("------扫雷游戏------\n\n");
}//布置雷 set_mine() 的定义
void set_mine(char mine[ROWS][COLS], int row, int col)
{//定义一个整型变量 n//并将 放置雷的个数 NUM 赋值给 nint n = NUM;// while 循环while (n){//定义两个整型变量 x y,//并将 rand() --随机数字的生成 函数 % row//生成的结果 分别 赋值给 x yint x = rand() % row + 1;int y = rand() % col + 1;//如果 mine[x][y] 的 内容 等于 ‘0’(字符0), 则执行下面的语句块if (mine[x][y] == '0'){//将 ‘1’(字符1) 赋值给 board[x][y]mine[x][y] = '1';//雷的个数 - 1(减1)n--;}}
}//排雷 clear_mine() 的定义
void clear_mine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{//输出打印 提示信息printf("一共有%d 个雷\n", NUM);//定义两个整型变量 x y,//并进行初始化,赋值为 0int x = 0;int y = 0;//定义两个整型变量 count,//用作计算第几次排雷次数 即避开了多少雷int count = 0;// while 循环,// 循环判断的条件是 count < NUM while (count < NUM){//输出打印 提示信息printf("\n欢迎您,请输入要排查的坐标\n");printf("提示1:(横、纵坐标中间用空格隔开)\n");printf("提示2:(横、纵坐标都是[1~9]):>");//输入 两个整型数字 int n2 = scanf("%d %d", &x, &y);//if 条件判断语句// 如果函数 x > 0 && x <= row && y > 0 && y <= col,执行下面的语句块// 即 if 条件判断条件是 输入的坐标是否有效if (x > 0 && x <= row && y > 0 && y <= col){// if 条件判断语句// 如果函数 board[x][y]的 内容 不等于 ‘1’(字符1),执行下面的语句块if (mine[x][y] != '1'){// if 条件判断语句// 如果函数 board[x][y]的 内容 等于 ‘*’(字符*),执行下面的语句块if (show[x][y] == '*'){//输出打印 提示信息printf("\n第%d次 排查!\n", count + 1);// 将mine[x - 1][y] + mine[x - 1][y - 1]// +mine[x][y - 1] + mine[x + 1][y - 1]// + mine[x + 1][y] + mine[x + 1][y + 1]// + mine[x][y + 1] + mine[x - 1][y + 1] 即统计求和 show[x][y] 四周 七个坐标的雷数// 并将结果以字符的形式赋值给 show[x][y] // (因为 mine[x][y]、show[x][y] 都是字符数组,元素必须是字符的形式!!!)show[x][y] = (mine[x - 1][y] + mine[x - 1][y - 1]+ mine[x][y - 1] + mine[x + 1][y - 1]+ mine[x + 1][y] + mine[x + 1][y + 1]+ mine[x][y + 1] + mine[x - 1][y + 1]) - 7 * '0';//输入的坐标有效,// 并且不是雷,// 还有没有被排查过// (三个条件同时满足!!!),// 则用作计算第几次排雷次数 即避开了多少雷的变量 count自增 1count++;//打印函数 Print() 的调用Print(show, ROW, COL);//如果用作计算第几次排雷次数 即避开了多少雷的变量 count//等于 ROW * COL -NUM 即(没有放置雷的个数),执行下面的语句块if (count == ( ROW * COL -NUM) ) {//输出打印 提示信息printf("恭喜您,你成功避开 %d个雷!\n", NUM);printf("棒棒哒!游戏结束!\n");//跳出循环break;}}//else{//输出打印 提示信息printf("\n该坐标已经排查过了,请重新输入!\n");}}// mine[x][y] == '1',即 mine[x][y] 里面的内容是雷。else{//输出打印提示信息printf("\n非常遗憾!你被炸死了!游戏结束!\n");//输出打印 提示信息printf("\n雷区布置展示:>\n");//打印函数 Print() 的调用Print(mine, ROW, COL);//跳出循环break;}}//else{//输出打印 提示信息printf("坐标非法,请输入有效坐标\n");}}
}
test.c 头文件
#define _CRT_SECURE_NO_WARNINGS 1#include"game.h"//引用 game.h 头文件//定义菜单 menu() 函数
void menu()
{//输出打印 提示信息printf("\n********************\n");printf("***** 1.play *****\n");printf("***** 0.exit *****\n");printf("********************\n\n");
}//
void game()
{// 定义一个二维的字符型数组,// 数组名字是 mine,// 有 ROWS 行、COLS 列char mine[ROWS][COLS];// 定义一个二维的字符型数组,// 数组名字是 show,// 有 ROWS 行、COLS 列char show[ROWS][COLS];//初始化函数 Init() 的调用Init(mine, ROWS, COLS,'0');//初始化函数 Init() 的调用Init(show, ROWS, COLS,'*');//输出打印 提示信息printf("\n扫雷游戏页面:>\n");//打印函数 Print() 的调用Print(show, ROW, COL);//布置雷 set_mine() 的调用set_mine(mine, ROW, COL);//输出打印 提示信息printf("\n雷区布置展示:>\n");//打印函数 Print() 的调用Print(mine, ROW, COL);//排雷 clear_mine() 的调用clear_mine(mine, show, ROW, COL);
}//定义测试函数 test()
void test()
{// rand 函数(随机数的生成函数)使用前,// 必须要提前引用 srand 函数,// time() 函数是时间戳函数srand((unsigned int)time(NULL));//定义一个整型变量 input//并且初始化为0int input = 0;//使用 do while 循环语句do{//调用 菜单函数menu();//打印提示信息printf("请选择:>");// n1 来接受 scanf 函数的返回值,// 输入一个整数int n1 = scanf("%d", &input);//使用 switch 分支语句switch (input){// 如果 input = 1// 执行 case 1:后面的语句case 1://调用 game()函数game();//break 语句用来跳出 switch 分支语句 break;case 0://打印提示信息printf("退出游戏\n");//break 语句用来跳出 switch 分支语句 break;default:// 如果 input 不等于 0 也不等于 1// 执行 default:后面的语句printf("选择错误,请重新选择\n");//break 语句用来跳出 switch 分支语句 break;}} while (input);//跳出 do-while 循环的条件是 input 等于 0
}//主函数
int main()
{//调用测试函数 test()test();return 0;
}
4、结果展示
提示:我写的是9*9的扫雷简易版游戏
(4.1)输入的坐标是非法的(即不在坐标的范围)

(4.2)输入的坐标是雷,则游戏提前结束

(4.3)输入的坐标 不是雷,打印四周(八个坐标)有几个雷

(4.4)成功避免所有布置的雷,游戏完美结束

5、END
每天都在学习的路上!
On The Way Of Learning

相关文章:
扫雷游戏(C语言详解)
扫雷游戏(C语言详解) 放在最前面的1、前言(扫雷游戏的简介)2、扫雷游戏的规则(简易版)3、代码实现(3.1)提醒一下:( i ) 提醒1:( ii ) 提醒2: &…...
信刻全自动光盘摆渡系统
随着各种数据传输、储存技术、信息技术的快速发展,保护信息安全是重中之重。各安全领域行业对跨网数据交互需求日益迫切。针对于业务需要与保密规范相关要求,涉及重要秘密信息,需做到安全的物理隔离,并且保证跨网数据高效安全传输…...
计算机网络的数据链路层
计算机网络的数据链路层 数据链路层是OSI参考模型中的第二层,它位于物理层之上,网络层之下。数据链路层的主要功能是在物理层提供的服务的基础上向网络层提供服务,其最基本的服务是将源自网络层来的数据可靠地传输到相邻节点的目标机网络层。…...
从0开始搭建一个生产级SpringBoot2.0.X项目(三)SpringBoot接口统一返回和全局异常处理
前言 最近有个想法想整理一个内容比较完整springboot项目初始化Demo。 SpringBoot接口统一返回和全局异常处理,使用ControllerAdvice ExceptionHandler 的组合来实现。 一、pom文件新增依赖 <dependency><groupId>com.alibaba</groupId><ar…...
Mybatis-plus-扩展功能
Mybatis-plus-扩展功能 一:代码生成器 AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各个模块的代码,极大的提升了开发效率。 功能的演示:…...
【AI辅助】AWS Toolkit+AmazonQ
#偶然看到网上某up主用的这个AI工具,感觉还挺实用的,推荐大家~我们不可阻挡AI的攻势,但是成为利用它的人,也是反侵占的方式呢# AWS toolkit Amazon Q 安装 VScode--Extensions--搜索工具--安装 安装后,工具栏会多出对…...
云手机简述(概况,使用场景,自己部署云手机)
背景 最近经常会看到云手机的相关广告,手痒难耐,了解一下。 我的主要需求: Android 已 root,能够做一些自动化等高级功能。能够通过 远程adb 控制手机。能够尽量的少花钱,最好是能够提供动态创建删除手机的方式&…...
Java已死,大模型才是未来?
作者:不惑_ 引言 在数字技术的浪潮中,编程语言始终扮演着至关重要的角色。Java,自1995年诞生以来,便以其跨平台的特性和丰富的生态系统,成为了全球范围内开发者们最为青睐的编程语言之一 然而,随着技术的…...
NCCL安装(Ubuntu等)
目录 一、NCCL的定义二、安装NCCL的原因1、加速多GPU通信2、支持流行的深度学习框架3、提高计算效率4、易于使用和集成5、可扩展性 三、NCCL安装方法1、下载安装包2、更新APT数据库3、使用APT安装libnccl2包,另外,如果需要使用NCCL编译应用程序ÿ…...
加载视频显示 - python 实现
#-*-coding:utf-8-*- # date:2021-03-21 # Author: DataBall - Xian # Function: 加载视频并显示import cv2 if __name__ "__main__":#加载视频cap cv2.VideoCapture(./video/1.mp4)while True:ret, img cap.read()# 获取相机图像if ret True:# 如果 ret 返回值为…...
数据结构模拟题[五]
数据结构试卷(五) 一、选择题 (20 分) 1.数据的最小单位是( )。 (A) 数据项 (B) 数据类型 (C) 数据元素 (D) 数据变量 2.设一组初始记录关键字序列为 (50 ,40, 95,20…...
IDEA切换窗口快捷键失效
问题描述: 在idea中,如果切换窗口的快捷键(Alt Tab)失效了,可以通过清除缓存的方式修复...
QT中使用图表之QChart绘制X轴为日期时间轴的折线图
显然X轴是日期时间轴的话,那么我们使用的轴类就得是QDateTimeAxis QChart中日期时间轴的精度是毫秒 因此图表里面的数据的x值需要是一个毫秒数,才能显示出来 --------------------------------------------------------------------------------------…...
【传知代码】短期电力负荷(论文复现)
🍑个人主页:Jupiter. 🚀 所属专栏:传知代码 欢迎大家点赞收藏评论😊 目录 备注前言介绍问题背景复现:一. 多维特征提取的提取框架:二. 论文中进行性能测试的MultiTag2Vec-STLF模型:三…...
ubuntu20.04 加固方案-设置重复登录失败后锁定时间限制
一、编辑PAM配置文件 打开终端。 使用文本编辑器(如vim)编辑/etc/pam.d/common-auth文件。 sudo vim /etc/pam.d/common-auth 二、添加配置参数 在打开的配置文件中,添加或修改以下参数: auth required pam_tally2.so deny5 un…...
【综合算法学习】(第十三篇)
目录 解数独(hard) 题目解析 讲解算法原理 编写代码 单词搜索(medium) 题目解析 解析算法原理 编写代码 解数独(hard) 题目解析 1.题目链接:. - 力扣(LeetCode)…...
Web3 Key Talking #4|Sui有何不同?及其发展路线图
活动时间: 2024 年 10 月 31 日(周四)20:00–21:00(UTC8) 会议链接: 腾讯会议 会议 ID :429–339–777 主持:Sanzhisanzhichazi1 嘉宾:uvdwangtxxl,Sui …...
Axios 请求超时设置无效的问题及解决方案
文章目录 Axios 请求超时设置无效的问题及解决方案1. 引言2. 理解 Axios 的超时机制2.1 Axios 超时的工作原理2.2 超时错误的处理 3. Axios 请求超时设置无效的常见原因3.1 配置错误或遗漏3.2 超时发生在建立连接之前3.3 使用了不支持的传输协议3.4 代理服务器或中间件干扰3.5 …...
数据结构+算法
一、数据结构 1、线性结构 数组: 访问:O(1)访问特定位置的元素;插入:O(n)最坏的情况发生在插入发生在数组的首部并需要移动所有元素时;删除:O(n)最坏的情况发生在删除数组的开头发生并需要移动第一元素后…...
利用ExcelJS封装一个excel表格的导出
ExcelJS 操作和写入Excel 文件。 直接上代码,js部分: exportFn.js import ExcelJS from exceljs; import { saveAs } from file-saver;export function exportExcleUtils(tHeader, filterVal, listData, fileName) {//设置工作簿属性const workbook ne…...
网络六边形受到攻击
大家读完觉得有帮助记得关注和点赞!!! 抽象 现代智能交通系统 (ITS) 的一个关键要求是能够以安全、可靠和匿名的方式从互联车辆和移动设备收集地理参考数据。Nexagon 协议建立在 IETF 定位器/ID 分离协议 (…...
【根据当天日期输出明天的日期(需对闰年做判定)。】2022-5-15
缘由根据当天日期输出明天的日期(需对闰年做判定)。日期类型结构体如下: struct data{ int year; int month; int day;};-编程语言-CSDN问答 struct mdata{ int year; int month; int day; }mdata; int 天数(int year, int month) {switch (month){case 1: case 3:…...
python打卡day49
知识点回顾: 通道注意力模块复习空间注意力模块CBAM的定义 作业:尝试对今天的模型检查参数数目,并用tensorboard查看训练过程 import torch import torch.nn as nn# 定义通道注意力 class ChannelAttention(nn.Module):def __init__(self,…...
使用分级同态加密防御梯度泄漏
抽象 联邦学习 (FL) 支持跨分布式客户端进行协作模型训练,而无需共享原始数据,这使其成为在互联和自动驾驶汽车 (CAV) 等领域保护隐私的机器学习的一种很有前途的方法。然而,最近的研究表明&…...
使用van-uploader 的UI组件,结合vue2如何实现图片上传组件的封装
以下是基于 vant-ui(适配 Vue2 版本 )实现截图中照片上传预览、删除功能,并封装成可复用组件的完整代码,包含样式和逻辑实现,可直接在 Vue2 项目中使用: 1. 封装的图片上传组件 ImageUploader.vue <te…...
基于Docker Compose部署Java微服务项目
一. 创建根项目 根项目(父项目)主要用于依赖管理 一些需要注意的点: 打包方式需要为 pom<modules>里需要注册子模块不要引入maven的打包插件,否则打包时会出问题 <?xml version"1.0" encoding"UTF-8…...
大学生职业发展与就业创业指导教学评价
这里是引用 作为软工2203/2204班的学生,我们非常感谢您在《大学生职业发展与就业创业指导》课程中的悉心教导。这门课程对我们即将面临实习和就业的工科学生来说至关重要,而您认真负责的教学态度,让课程的每一部分都充满了实用价值。 尤其让我…...
今日学习:Spring线程池|并发修改异常|链路丢失|登录续期|VIP过期策略|数值类缓存
文章目录 优雅版线程池ThreadPoolTaskExecutor和ThreadPoolTaskExecutor的装饰器并发修改异常并发修改异常简介实现机制设计原因及意义 使用线程池造成的链路丢失问题线程池导致的链路丢失问题发生原因 常见解决方法更好的解决方法设计精妙之处 登录续期登录续期常见实现方式特…...
Mobile ALOHA全身模仿学习
一、题目 Mobile ALOHA:通过低成本全身远程操作学习双手移动操作 传统模仿学习(Imitation Learning)缺点:聚焦与桌面操作,缺乏通用任务所需的移动性和灵活性 本论文优点:(1)在ALOHA…...
深度学习习题2
1.如果增加神经网络的宽度,精确度会增加到一个特定阈值后,便开始降低。造成这一现象的可能原因是什么? A、即使增加卷积核的数量,只有少部分的核会被用作预测 B、当卷积核数量增加时,神经网络的预测能力会降低 C、当卷…...
