扫雷游戏(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…...

AI 原生时代,更要上云:百度智能云云原生创新实践
本文整理自百度云智峰会 2024 —— 云原生论坛的同名演讲。 我今天分享的主题,是谈谈在云计算和 AI 技术快速发展和深入落地的背景下,百度智能云在云原生的基础设施产品和技术层面做的一些创新实践。 毋庸置疑,过去十几年云计算和 AI 技术是…...

C语言程序编译运行
程序功能:使用 printf() 输出 “Hello, World!”。 C语言源程序: #include <stdio.h> int main() {// printf() 中字符串需要引号printf("Hello, World!");return 0; }编译过程: vim hello.c gcc hello.c -o hello ./hell…...

视频点播系统扩展示例
更多的前端页面(如视频详情页、用户注册页等)。更复杂的业务逻辑(如视频评论、搜索功能等)。安全性和权限管理(如用户角色管理、权限控制等)。其他技术细节(如文件上传、分页查询等)…...

echo $? —— Linux 中的退出状态码详解
在 Linux 系统中,echo $? 是一个非常重要的命令,用于显示上一条命令的退出状态码。这个小小的符号组合可以帮助我们判断命令是否成功执行,同时也为编写自动化脚本提供了基础支持。本文将详细介绍 echo $? 的用法及其在实际开发中的应用。 …...

heic格式转化jpg最简单方法?快来学习这几种简单的转换方法!
heic格式转化jpg最简单方法?在当今的数字图像处理领域,HEIC格式以其卓越的压缩效率和高质量图像表现,正逐渐崭露头角并受到业界的深切关注,HEIC格式凭借先进的压缩技术,成功地在保持图像清晰度的同时,大幅度…...

力扣(leetcode)每日一题 3259 超级饮料的最大强化能量|动态规划
3259. 超级饮料的最大强化能量 题干 来自未来的体育科学家给你两个整数数组 energyDrinkA 和 energyDrinkB,数组长度都等于 n。这两个数组分别代表 A、B 两种不同能量饮料每小时所能提供的强化能量。 你需要每小时饮用一种能量饮料来 最大化 你的总强化能量。然而…...

Webserver(2.7)内存映射
目录 内存映射内存映射相关系统调用内存映射的注意事项如果对mmap的返回值(ptr)做操作,释放内存(munmap)是否能够成功?如果open时O_RDONLY,mmap时prot参数指定PROT_READ | PROT_WRITE会怎样?如果文件偏移量…...

vue3父子组件传值,子组件暴漏方法
1.父传子 defineProps 父组件直接通过属性绑定的方式给子组件绑定数据,子组件通过defineProps接收函数接收 其中v-model是完成事件绑定和事件监听的语法糖。v-model算是v-bind和v-on的简洁写法,等价于 <c-input ref"inputRef" :modelValue…...

Linux_04 Linux常用命令——tar
一、命令格式 tar [选项] [归档文件] [要处理的文件或目录]1、选项 c创建归档文件x解压缩归档文件z使用gzipj使用bzip2v处理过程显示信息f指定归档文件名称 2、归档文件-可指定目录及文件名 /home/wang.tar.gz 3、要处理的文件或目录 /home/study1/wang 二、常见命令 t…...

Java项目实战II基于Java+Spring Boot+MySQL的编程训练系统(源码+数据库+文档)
目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发,CSDN平台Java领域新星创作者,专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末 一、前言 在当今数字…...