当前位置: 首页 > news >正文

扫雷游戏(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语言详解)

扫雷游戏&#xff08;C语言详解&#xff09; 放在最前面的1、前言&#xff08;扫雷游戏的简介&#xff09;2、扫雷游戏的规则&#xff08;简易版&#xff09;3、代码实现&#xff08;3.1&#xff09;提醒一下&#xff1a;( i ) 提醒1&#xff1a;( ii ) 提醒2&#xff1a; &…...

信刻全自动光盘摆渡系统

随着各种数据传输、储存技术、信息技术的快速发展&#xff0c;保护信息安全是重中之重。各安全领域行业对跨网数据交互需求日益迫切。针对于业务需要与保密规范相关要求&#xff0c;涉及重要秘密信息&#xff0c;需做到安全的物理隔离&#xff0c;并且保证跨网数据高效安全传输…...

计算机网络的数据链路层

计算机网络的数据链路层 数据链路层是OSI参考模型中的第二层&#xff0c;它位于物理层之上&#xff0c;网络层之下。数据链路层的主要功能是在物理层提供的服务的基础上向网络层提供服务&#xff0c;其最基本的服务是将源自网络层来的数据可靠地传输到相邻节点的目标机网络层。…...

从0开始搭建一个生产级SpringBoot2.0.X项目(三)SpringBoot接口统一返回和全局异常处理

前言 最近有个想法想整理一个内容比较完整springboot项目初始化Demo。 SpringBoot接口统一返回和全局异常处理&#xff0c;使用ControllerAdvice ExceptionHandler 的组合来实现。 一、pom文件新增依赖 <dependency><groupId>com.alibaba</groupId><ar…...

Mybatis-plus-扩展功能

Mybatis-plus-扩展功能 一&#xff1a;代码生成器 AutoGenerator 是 MyBatis-Plus 的代码生成器&#xff0c;通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各个模块的代码&#xff0c;极大的提升了开发效率。 功能的演示&#xff1a…...

【AI辅助】AWS Toolkit+AmazonQ

#偶然看到网上某up主用的这个AI工具&#xff0c;感觉还挺实用的&#xff0c;推荐大家~我们不可阻挡AI的攻势&#xff0c;但是成为利用它的人&#xff0c;也是反侵占的方式呢# AWS toolkit Amazon Q 安装 VScode--Extensions--搜索工具--安装 安装后&#xff0c;工具栏会多出对…...

云手机简述(概况,使用场景,自己部署云手机)

背景 最近经常会看到云手机的相关广告&#xff0c;手痒难耐&#xff0c;了解一下。 我的主要需求&#xff1a; Android 已 root&#xff0c;能够做一些自动化等高级功能。能够通过 远程adb 控制手机。能够尽量的少花钱&#xff0c;最好是能够提供动态创建删除手机的方式&…...

Java已死,大模型才是未来?

作者&#xff1a;不惑_ 引言 在数字技术的浪潮中&#xff0c;编程语言始终扮演着至关重要的角色。Java&#xff0c;自1995年诞生以来&#xff0c;便以其跨平台的特性和丰富的生态系统&#xff0c;成为了全球范围内开发者们最为青睐的编程语言之一 然而&#xff0c;随着技术的…...

NCCL安装(Ubuntu等)

目录 一、NCCL的定义二、安装NCCL的原因1、加速多GPU通信2、支持流行的深度学习框架3、提高计算效率4、易于使用和集成5、可扩展性 三、NCCL安装方法1、下载安装包2、更新APT数据库3、使用APT安装libnccl2包&#xff0c;另外&#xff0c;如果需要使用NCCL编译应用程序&#xff…...

加载视频显示 - 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 返回值为…...

数据结构模拟题[五]

数据结构试卷&#xff08;五&#xff09; 一、选择题 (20 分) 1&#xff0e;数据的最小单位是&#xff08; &#xff09;。 (A) 数据项 (B) 数据类型 (C) 数据元素 (D) 数据变量 2&#xff0e;设一组初始记录关键字序列为 (50 &#xff0c;40&#xff0c; 95&#xff0c;20…...

IDEA切换窗口快捷键失效

问题描述&#xff1a; 在idea中&#xff0c;如果切换窗口的快捷键&#xff08;Alt Tab&#xff09;失效了&#xff0c;可以通过清除缓存的方式修复...

QT中使用图表之QChart绘制X轴为日期时间轴的折线图

显然X轴是日期时间轴的话&#xff0c;那么我们使用的轴类就得是QDateTimeAxis QChart中日期时间轴的精度是毫秒 因此图表里面的数据的x值需要是一个毫秒数&#xff0c;才能显示出来 --------------------------------------------------------------------------------------…...

【传知代码】短期电力负荷(论文复现)

&#x1f351;个人主页&#xff1a;Jupiter. &#x1f680; 所属专栏&#xff1a;传知代码 欢迎大家点赞收藏评论&#x1f60a; 目录 备注前言介绍问题背景复现&#xff1a;一. 多维特征提取的提取框架&#xff1a;二. 论文中进行性能测试的MultiTag2Vec-STLF模型&#xff1a;三…...

ubuntu20.04 加固方案-设置重复登录失败后锁定时间限制

一、编辑PAM配置文件 打开终端。 使用文本编辑器&#xff08;如vim&#xff09;编辑/etc/pam.d/common-auth文件。 sudo vim /etc/pam.d/common-auth 二、添加配置参数 在打开的配置文件中&#xff0c;添加或修改以下参数&#xff1a; auth required pam_tally2.so deny5 un…...

【综合算法学习】(第十三篇)

目录 解数独&#xff08;hard&#xff09; 题目解析 讲解算法原理 编写代码 单词搜索&#xff08;medium&#xff09; 题目解析 解析算法原理 编写代码 解数独&#xff08;hard&#xff09; 题目解析 1.题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09;…...

Web3 Key Talking #4|Sui有何不同?及其发展路线图

活动时间&#xff1a; 2024 年 10 月 31 日&#xff08;周四&#xff09;20:00–21:00&#xff08;UTC8&#xff09; 会议链接&#xff1a; 腾讯会议 会议 ID &#xff1a;429–339–777 主持&#xff1a;Sanzhisanzhichazi1 嘉宾&#xff1a;uvdwangtxxl&#xff0c;Sui …...

Axios 请求超时设置无效的问题及解决方案

文章目录 Axios 请求超时设置无效的问题及解决方案1. 引言2. 理解 Axios 的超时机制2.1 Axios 超时的工作原理2.2 超时错误的处理 3. Axios 请求超时设置无效的常见原因3.1 配置错误或遗漏3.2 超时发生在建立连接之前3.3 使用了不支持的传输协议3.4 代理服务器或中间件干扰3.5 …...

数据结构+算法

一、数据结构 1、线性结构 数组&#xff1a; 访问&#xff1a;O(1)访问特定位置的元素&#xff1b;插入&#xff1a;O(n)最坏的情况发生在插入发生在数组的首部并需要移动所有元素时&#xff1b;删除&#xff1a;O(n)最坏的情况发生在删除数组的开头发生并需要移动第一元素后…...

利用ExcelJS封装一个excel表格的导出

ExcelJS 操作和写入Excel 文件。 直接上代码&#xff0c;js部分&#xff1a; exportFn.js import ExcelJS from exceljs; import { saveAs } from file-saver;export function exportExcleUtils(tHeader, filterVal, listData, fileName) {//设置工作簿属性const workbook ne…...

2025盘古石杯决赛【手机取证】

前言 第三届盘古石杯国际电子数据取证大赛决赛 最后一题没有解出来&#xff0c;实在找不到&#xff0c;希望有大佬教一下我。 还有就会议时间&#xff0c;我感觉不是图片时间&#xff0c;因为在电脑看到是其他时间用老会议系统开的会。 手机取证 1、分析鸿蒙手机检材&#x…...

uniapp微信小程序视频实时流+pc端预览方案

方案类型技术实现是否免费优点缺点适用场景延迟范围开发复杂度​WebSocket图片帧​定时拍照Base64传输✅ 完全免费无需服务器 纯前端实现高延迟高流量 帧率极低个人demo测试 超低频监控500ms-2s⭐⭐​RTMP推流​TRTC/即构SDK推流❌ 付费方案 &#xff08;部分有免费额度&#x…...

HDFS分布式存储 zookeeper

hadoop介绍 狭义上hadoop是指apache的一款开源软件 用java语言实现开源框架&#xff0c;允许使用简单的变成模型跨计算机对大型集群进行分布式处理&#xff08;1.海量的数据存储 2.海量数据的计算&#xff09;Hadoop核心组件 hdfs&#xff08;分布式文件存储系统&#xff09;&a…...

iview框架主题色的应用

1.下载 less要使用3.0.0以下的版本 npm install less2.7.3 npm install less-loader4.0.52./src/config/theme.js文件 module.exports {yellow: {theme-color: #FDCE04},blue: {theme-color: #547CE7} }在sass中使用theme配置的颜色主题&#xff0c;无需引入&#xff0c;直接可…...

MacOS下Homebrew国内镜像加速指南(2025最新国内镜像加速)

macos brew国内镜像加速方法 brew install 加速formula.jws.json下载慢加速 &#x1f37a; 最新版brew安装慢到怀疑人生&#xff1f;别怕&#xff0c;教你轻松起飞&#xff01; 最近Homebrew更新至最新版&#xff0c;每次执行 brew 命令时都会自动从官方地址 https://formulae.…...

【Veristand】Veristand环境安装教程-Linux RT / Windows

首先声明&#xff0c;此教程是针对Simulink编译模型并导入Veristand中编写的&#xff0c;同时需要注意的是老用户编译可能用的是Veristand Model Framework&#xff0c;那个是历史版本&#xff0c;且NI不会再维护&#xff0c;新版本编译支持为VeriStand Model Generation Suppo…...

Linux 下 DMA 内存映射浅析

序 系统 I/O 设备驱动程序通常调用其特定子系统的接口为 DMA 分配内存&#xff0c;但最终会调到 DMA 子系统的dma_alloc_coherent()/dma_alloc_attrs() 等接口。 关于 dma_alloc_coherent 接口详细的代码讲解、调用流程&#xff0c;可以参考这篇文章&#xff0c;我觉得写的非常…...

jdbc查询mysql数据库时,出现id顺序错误的情况

我在repository中的查询语句如下所示&#xff0c;即传入一个List<intager>的数据&#xff0c;返回这些id的问题列表。但是由于数据库查询时ID列表的顺序与预期不一致&#xff0c;会导致返回的id是从小到大排列的&#xff0c;但我不希望这样。 Query("SELECT NEW com…...

【1】跨越技术栈鸿沟:字节跳动开源TRAE AI编程IDE的实战体验

2024年初&#xff0c;人工智能编程工具领域发生了一次静默的变革。当字节跳动宣布退出其TRAE项目&#xff08;一款融合大型语言模型能力的云端AI编程IDE&#xff09;时&#xff0c;技术社区曾短暂叹息。然而这一退场并非终点——通过开源社区的接力&#xff0c;TRAE在WayToAGI等…...

LUA+Reids实现库存秒杀预扣减 记录流水 以及自己的思考

目录 lua脚本 记录流水 记录流水的作用 流水什么时候删除 我们在做库存扣减的时候&#xff0c;显示基于Lua脚本和Redis实现的预扣减 这样可以在秒杀扣减的时候保证操作的原子性和高效性 lua脚本 // ... 已有代码 ...Overridepublic InventoryResponse decrease(Inventor…...