C++:扫雷游戏

一.扫雷游戏项目设计

1.文件结构设计

首先我们要先定义三个文件

①test.c //文件中写游戏的测试逻辑 
②game.c //文件中写游戏中函数的实现等
③game.h //文件中写游戏需要的数据类型和函数声明等


2.扫雷游戏的主体结构

使⽤控制台实现经典的扫雷游戏

•游戏可以通过菜单实现继续玩或者退出游戏

•扫雷的棋盘是9*9的格子

•默认随机布置10个雷

•可以排查雷

◦如果位置不是雷,就显⽰周围有⼏个雷

◦如果位置是雷,就炸死游戏结束

◦把除10个雷之外的所有⾮雷都找出来,排雷成功,游戏结束

我们期待的游戏的界面应该是:

①初始界面


②排雷界面

 ③排雷失败界面

 

 3.面临的问题

因为我们需要在9*9的棋盘上布置雷的信息和排查雷,我们首先想到的就是创建⼀个9*9的数组来存放信息。
①返回雷的个数的越界的问题

当我们选定一个坐标时,如(x,y)我们想要得到(x,y)坐标周围8个坐标雷的总数


 

 所以,我们不得不考虑以下越界访问的问题

 为了解决以上问题,我可以将9*9栋棋盘扩大为11*11,这样就解决了棋盘越界的问题,如下图

 但注意:初始化棋盘时,11*11的格子都要进行初始化。

②保存雷的信息与显示雷的信息

继续分析,我们在棋盘上布置了雷,棋盘上雷的信息(1)和⾮雷的信息(0),假设我们排查了某⼀个位置后,这个坐标处不是雷,这个坐标的周围有1个雷,那我们需要将排查出的雷的数量信息记录存储,并打印出来,作为排雷的重要参考信息的。那这个雷的个数信息存放在哪⾥呢?如果存放在布置雷的数组中,这样雷的信息和雷的个数信息就可能或产⽣混淆和打印上的困难

这里我们采用另外⼀种方案,我们专⻔给⼀个棋盘(对应⼀个数组mine)存放布置好的雷的信息,再给另外⼀个棋盘(对应另外⼀个数组show)存放排查出的雷的信息。这样就互不⼲扰了,把雷布置到mine数组,在mine数组中排查雷,排查出的数据存放在show数组,并且打印show数组的信息给后期排查参考。

show数组开始时初始化为字符 '*',为了保持两个数组的类型⼀致,可以使⽤同⼀套函数处理,mine数组最开始也初始化为字符'0',布置雷改成'1'。

 布置雷的mine棋盘

 

 显示雷的show棋盘

 

二.扫雷游戏的简单模拟实现

1.game.h

 以上代码是扫雷游戏开发。代码包含常用库引入及标准命名空间使用声明。通过宏定义设置棋盘行列及雷数等参数。还声明了一系列函数,涵盖棋盘初始化、打印、布雷、统计雷数以及扫雷等功能,为实现完整扫雷游戏逻辑搭建了基本框架。

 

2. game.cpp

 实现扫雷游戏中棋盘初始化和打印功能。 InitBoard  函数通过双重循环,将指定字符填充到棋盘二维数组对应位置,完成初始化。 PrintBoard  函数先输出游戏标题,再用循环按行列格式打印棋盘元素,同时打印行列索引,方便玩家查看,为游戏交互提供基础展示。

 

          实现扫雷游戏中布雷和统计雷数功能。 SetMine  函数利用  rand  函数生成随机坐标,在棋盘数组上随机放置地雷(用  '1'  表示),直到达到设定雷数。( EASY_COUNT )。 GetMineCount  函数通过计算目标坐标周围八个格子的字符数值总和并做相应转换,统计出周围雷的数量,为玩家判断提供依据。

 以上是雷游戏核心逻辑的代码。 FindMine  函数负责游戏流程:

 ①玩家循环输入坐标,程序先检查坐标合法性及是否已排查。

 ②若坐标对应格子有雷( a[x][y] == '1'  ),游戏结束并显示雷区。

 ③无雷时,调用  GetMineCount  统计周围雷数并显示在显示棋盘  b  上,成功排查一格  win  计数加一。

 ④当排查格子数达到总格子数减去雷数( win == ROW * COL - EASY_COUNT  ),玩家胜利并显示雷区。 代码通过这些逻辑实现了扫雷游戏基本交互和胜负判定。

 

3.test.cpp

 测试扫雷游戏的代码片段。 menu  函数输出游戏菜单,提供 “退出(0)” 和 “开始游戏(1)” 选项。 game  函数则是游戏核心流程,先定义存放雷和显示信息的二维字符数组,接着调用  InitBoard  分别将其初始化为全  '0'  和全  '*'  ,再通过  PrintBoard  打印初始棋盘,然后调用  SetMine  布置地雷,最后调用  FindMine  让玩家开始排查地雷,逐步推进游戏进程。

 构建扫雷游戏的主逻辑框架。 test  函数中,先设置随机数种子,随后通过 do - while  循环展示游戏菜单,获取玩家输入。利用 switch  语句判断输入,0代表退出游戏,1则调用 game  函数开启游戏,输入错误时给予提示并要求重新输入。 main  函数通过 clock  函数记录游戏开始和结束时间,计算并输出游戏总耗时,为玩家提供完整的游戏交互和时间统计功能。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/229.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

k8s的pod挂载共享内存

k8s的pod挂载共享内存,限制不生效问题: 注:/dev/shm 是 Linux 系统中用于共享内存的特殊路径。通过将 emptyDir 的 medium 设置为 Memory,可以确保 /dev/shm 正确地挂载到一个基于内存的文件系统,从而实现高效的共享内…

【Linux学习笔记】基础IO之理解文件

【Linux学习笔记】基础IO之理解文件 🔥个人主页:大白的编程日记 🔥专栏:Linux学习笔记 前言 哈喽,各位小伙伴大家好!上期我们讲了进程替换 今天我们讲的是基础IO之理解文件。话不多说,我们进入正题&#…

XL32F001国产低成本单片机,24MHz主频,24KB Flash,3KB SRAM

XL32F001 是一颗基于ARM Cortex-M0内核的32 位微控制器,专为低成本、低功耗、小型化嵌入式系统设计,适合对资源需求中等但强调性价比和能效的场景。主频可达24M,内存方面有24KB Flash和3KB SRAM,适用于资源需求不大的应用场景。1.…

Oracle免费认证来袭

1、Oracle Cloud Infrastructure 2025 Foundations Associate” 🔗 考证地址:https://mylearn.oracle.com/ou/exam-unproctored/oracle-cloud-infrastructure-2025-foundations-associate-1z0-1085-25/148056/241954 2、Oracle Cloud Infrastructure 2…

C++ 完美转发

C 完美转发逐步详解 1. 问题背景与核心目标 在 C 模板编程中&#xff0c;若直接将参数传递给其他函数&#xff0c;参数的 值类别&#xff08;左值/右值&#xff09;和 类型信息&#xff08;如 const&#xff09;可能会丢失。例如&#xff1a; template<typename T> voi…

第2章 算法分析基础

2-1 算法的时间复杂度分析 2.1.1 输入规模与基本语句 输入规模&#xff1a;算法处理数据的规模&#xff0c;通常用 n 表示。 基本语句&#xff1a;执行次数与输入规模直接相关的关键操作。 例2.1 顺序查找 int SeqSearch(int A[], int n, int k) { for (int i 0; i < n…

4.系统定时器基本定时器

目录 系统定时器 系统定时器&#xff08;systick&#xff09;--内核 系统定时器结构 系统滴答定时器寄存器--内核 定时周期的确定公式 配置滴答定时器 系统定时器应用 应用1.定时器构造时间点任务&#xff0c;解决while循环阻塞问题 应用2.定时器构造精准的ms延时 应…

基于SpringBoot和PostGIS的应急运输事件影响分析-以1.31侧翻事故为例

目录 前言 一、技术实现路径 1、需要使用的数据 2、空间分析方法 二、相关模块设计与实现 1、运输路线重现开发 2、事故点影响范围实现 3、WebGIS可视化实现 三、讨论 1、界面结果展示 2、影响范围分析 四、总结 前言 在交通运输发达的当今社会&#xff0c;应急运输…

Python爬虫(20)Python爬虫数据存储技巧:二进制格式(Pickle/Parquet)性能优化实战

目录 背景介绍一、二进制存储的核心优势二、Python Pickle&#xff1a;轻量级对象序列化1. 基本介绍2. 代码示例3. 性能与局限性 三、Apache Parquet&#xff1a;列式存储的工业级方案1. 基本介绍2. 代码示例&#xff08;使用PyArrow库&#xff09;3. 核心优势 四、性能对比与选…

C++从入门到实战(十三)C++函数模板与类模板初阶讲解

C从入门到实战&#xff08;十三&#xff09;C函数模板与类模板初阶讲解 前言一、为什么需要模板1. 函数重载的问题2. 泛型编程和模板的作用 二、函数模板2.1 函数模板格式2.2 函数模板的原理2.3 函数模板的实例化&#xff08;1&#xff09;隐式实例化&#xff1a;&#xff08;2…

游戏引擎学习第261天:切换到静态帧数组

game_debug.cpp: 将ProfileGraph的尺寸初始化为相对较大的值 今天的讨论主要围绕性能分析器&#xff08;Profiler&#xff09;以及如何改进它的可用性展开。当前性能分析器已经能够正常工作&#xff0c;但我们希望通过一些改进&#xff0c;使其更易于使用&#xff0c;特别是在…

《Python星球日记》 第36天:线性代数基础

名人说:路漫漫其修远兮,吾将上下而求索。—— 屈原《离骚》 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 专栏:《Python星球日记》,限时特价订阅中ing 目录 一、标量、向量、矩阵的基本概念1. 标量2. 向量3. 矩阵二、矩阵运算1. 矩阵加法2. 矩阵乘法3. 矩…