居然这么简单就能实现扫雷游戏!
目录
一.思路
1.成果展示
2.思路
二.具体操作
1.创建"棋盘"
2.初始化雷
3.布置雷
4.打印
5.排除雷
三.代码实现
1.test.c文件
2.thunder.h文件
3.thunder.c文件
Hello,大家好,今天我们来实现扫雷游戏,希望这一篇博客能给带给大家一些收获。
一.思路
1.成果展示
在真正开始讲解之前,我们先来看一下我的成果展示:
屏幕录制 2024-07-03 165322-CSDN直播
2.思路
我们先来讲解一下扫雷游戏的思路:这个思路就是和我们在完游戏时候的那个思路时一模一样的,就是排除雷,简单来说,就是我们给定一个位置,看这个位置是不是雷,如果我们不幸,选中的这个位置就刚好是一个雷的话,那么我们就被炸死了,反之如果这个位置不是雷的话,那么,相应的,我们就要统计一下这个位置旁边与这个位置相邻的位置中雷的个数。
二.具体操作
1.创建"棋盘"
实际上就是创建框架,就是创建如下面所示的一个"棋盘"。
我们首先要创建一个如上图一样的类似于"棋盘"一样的框架,要制作这个框架其实是很简单的,就是建立一个二维数组就可以了,将数组中的所有的元素均设置成 ' * ' 就可以了。这里我们在创建框架的时候需要注意一件事情,就必须要创建两个一模一样的二维数组,大家不妨看一看我们上面的那个游戏思路,如果这个位置是雷,我们就"死了",反之,就要在这个位置上写上周围的所有位置的雷的数目总和。为了区分有雷和无雷,我们将有雷的位置赋值1,无雷的位置赋值为0,那么,这样的话,我们在玩游戏的过程中出现了1的话,我们是无法知道这个位置是雷还是说这个位置不是雷,周围总共有1个雷?如果我们只是使用一个二维数组的话,是无法明白这个出现的1的含义的,会让我们产生歧义。因此,我们在这里要使用两个一模一样的数组来实现,我们呈现在屏幕上面的"棋盘"样式就是上面的那幅图所示,由于 ' * ' 符号属于字符,因此,我们要建立一个字符数组,但是如果按照我们上面所说的那样的话,一个数组是int类型,另一个数组是char类型,这样写的话有一点点麻烦,为了统一,我们这里将两个数组均写成是char类型的。
2.初始化雷
通过上面的思路我们可知我们建立了两个char类型的数组,我们接下来就要进行初始化操作了,在进行初始化操作之前,我们首先要知道创建的两个数组是干什么的,一个数组是用来布置雷的,我们为了方便,将雷使用字符 ' 1 ' 来表示,不是雷的位置使用字符 ' 0 ' 来表示,这个数组我们不可以展示出来(因为这个数组中存放的是雷的分布情况),另一个数组就是我们要展示出来的数组,是用来显示我们要查的这个位置又没有雷的存在。
我们将不展示出来的这个数组命名为mine数组,如下图所示:
mine数组我们在进行初始化的时候,将这个数组中的所有的元素全部初始化为字符 ' 0 ' (通过我们上面的解释我们可知 ' 0 ' 代表的是要排查的这个位置没有雷)。
我们将展示出来的这个数组命名为show数组,如下图所示:
show数组我们在进行初始化的时候,将这个数组中的所有元素全部初始化为 ' * ' ,我们这个数组是作为展示的一个数组,因此,我们不能暴露里面的雷的放置情况。
3.布置雷
我们的雷的布置这一操作是在mine数组中进行的,我们的"棋盘"是采用的是 9 * 9实现的,我们这里在布置是只布置10个雷就i可以了,我们是要在这个"棋盘"中去进行雷的布置的,因此,不能超过这个"棋盘"的范围,这里我们要使用一个函数,就是 rand( ) 函数,下面是关于这个函数的链接,大家可以去了解一下,这个函数可以随机生成一个随机数,
rand - C++ Referencehttps://legacy.cplusplus.com/reference/cstdlib/rand/?kw=rand我们可以通过这个函数来确定雷的位置,使用这个函数我们就可以得到两个值x,y作为坐标来确定一个地址(这个地址必须在mine函数的范围之内),将这个地址赋值为字符 ' 1 ' ,利用循环,创建10个雷。
4.打印
我们在进行打印这一操作的时候,就是将mine数组和show数组中的各个元素均打印到屏幕上即可,这里使用for循环,(最后有代码)。
5.排除雷
前面的几步都是我们的准备操作,这一步才是我们玩游戏的步骤,我们给定一个坐标位置,去判断这个位置是否有雷(判断这一步操作是在mine数组中判断的(雷的分布是在mine数组中的)),若mine数组中这个位置是字符 ' 1 ' 的话,就说明我们碰到雷了,反之,若mine数组中这个位置是字符 ' 0 ' 的话,我们就要去统计一下这个位置周围的位置的雷的个数,然后将这个个数转化为字符赋值给show数组中的这个相同的位置,为了方便观看,我们这里将show数组在打印到屏幕上就可以了,这里还要有一个结束条件,就是我们将所有的雷全部都排完之后,我们就扫雷成功了,因此,我们还要定义一个变量来表示我们找到的非雷位置的个数,用这个变量来表示雷有没有被扫完。
三.代码实现
1.test.c文件
#include"thunder.h"
void menu()
{printf("********************\n");printf("**** 1.play ****\n");printf("**** 0.exit ****\n");printf("********************\n");
}
void game()
{char mine[COWS][COLS] = { 0 };char show[COWS][COLS] = { 0 };// 初始化雷Initebroad(mine, COWS, COLS, '0');Initebroad(show, COWS, COLS, '*');// 布置雷Setmine(mine, COW, COL);// 打印Displaydroad(mine, COW, COL);Displaydroad(show, COW, COL);// 排除雷Findmine(mine, show, COW, COL);
}
void test()
{int input = 0;srand((unsigned int)time(NULL));do{menu();printf("请选择:");scanf("%d", &input);switch (input){case 1:game();break;case 0:printf("游戏结束,退出游戏\n");break;default:printf("输入错误,请重新输入\n");}} while (input);
}
int main()
{test();return 0;
}
2.thunder.h文件
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<string.h>
#define COW 9
#define COL 9
#define COWS COW+2
#define COLS COL+2
#define mount 10
void Initebroad(char arr[COWS][COLS], int cows, int cols, char set);
void Setmine(char arr[COWS][COLS], int cow, int col);
void Displaydroad(char arr[COWS][COLS], int cows, int cols);
void Findmine(char mine[COWS][COLS], char show[COWS][COLS], int cow, int col);
3.thunder.c文件
#include"thunder.h"
void Initebroad(char arr[COWS][COLS], int cows, int cols, char set)
{for (int i = 0; i < cows; i++){for (int j = 0; j < cols; j++){arr[i][j] = set;}}
}
void Setmine(char arr[COWS][COLS], int cow, int col)
{int count = mount;while (count > 0){int x = rand() % cow + 1;int y = rand() % col + 1;if (arr[x][y] == '0'){arr[x][y] = '1';count--;}}
}
void Displaydroad(char arr[COWS][COLS], int cow, int col)
{ printf("------开始游戏-----\n");for (int i = 0; i <= col; i++) {printf("%d ",i);}printf("\n");for (int i = 1; i <= cow; i++){printf("%d ",i);for (int j = 1; j <= col; j++){printf("%c ", arr[i][j]);}printf("\n");}
}
//static这个关键字可以保证这个函数只能在当前.c文件中使用,其他的文件使用不了。
static int Getminecount(char arr[COWS][COLS], int x, int y)
{int count = 0;for (int i = x - 1; i <= x + 1; i++){for (int j = y - 1; j <= y + 1; j++){count += arr[i][j] - '0';}}return count;
}
void Findmine(char mine[COWS][COLS], char show[COWS][COLS], int cow, int col)
{int x = 0, y = 0;int win = 0;while (win < cow * col - mount)//确保雷全部被排完。{ printf("请输入要排查的坐标位置\n");scanf("%d %d", &x, &y);if (x >= 1 && x <= cow && y >= 1 && y <= col){if (show[x][y] == '*'){if (mine[x][y] == '1'){printf("很遗憾,您被炸死了\n");Displaydroad(show, COW, COL);break;}else{// 当程序进行到这里时,就说明要排查的当前位置不是雷,那么,就要统计周围一圈的雷的个数。int count = Getminecount(mine, x, y);show[x][y] = count + '0';Displaydroad(show, COW, COL);win++;}}else{printf("这个位置您已经排查过了,请另排查一个\n");}}else{printf("输入的坐标不存在,请重新输入\n");}}if (win == cow * col - mount){printf("恭喜您,排雷成功\n");Displaydroad(mine, COW, COL);}
}
OK,以上就是我们对于扫雷游戏的全部讲解了,希望能对大家有所收获,感谢大家的支持。
相关文章:

居然这么简单就能实现扫雷游戏!
目录 一.思路 1.成果展示 2.思路 二.具体操作 1.创建"棋盘" 2.初始化雷 3.布置雷 4.打印 5.排除雷 三.代码实现 1.test.c文件 2.thunder.h文件 3.thunder.c文件 Hello,大家好,今天我们来实现扫雷游戏,希望这一篇博客能给带给大家一…...

安装Gitlab+Jenkins
GItlab概述 GitLab概述: 是一个利用 Ruby on Rails 开发的开源应用程序,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目。 Ruby on Rails 是一个可以使你开发、部署、维护 web 应用程序变得简单的框架。 GitLab拥有与…...
php 命令行模式详解
PHP 的命令行模式(Command Line Interface, CLI)是 PHP 的一个特定版本或运行时配置,它允许 PHP 脚本在没有 Web 服务器的情况下直接在命令行环境中执行。CLI 版本的 PHP 通常不包含 CGI 或者其他 web server 接口,因此更轻量级&a…...

Git 基础-创建版本库 git init、添加到暂存区git add、查看状态git status、查看改动git diff
目录 1.创建版本库 git init 1.创建版本库 git init 在目录中创建新的 Git 仓库。 你可以在任何时候、任何目录中这么做,完全是本地化的。 在目录中执行 git init,就可以创建一个 Git 仓库了。 注意: 没事不要手动修改 .git 目录里面的文件,不…...

Python实现无头浏览器采集应用的反爬虫与反检测功能解析与应对策略
Python实现无头浏览器采集应用的反爬虫与反检测功能解析与应对策略 随着网络数据的快速增长,爬虫技术在数据采集、信息分析和业务发展中扮演着重要的角色。然而,随之而来的反爬虫技术也在不断升级,给爬虫应用的开发和维护带来了挑战。为了应…...
法国工程师IMT联盟 密码学及其应用 2023年期末考试题
1 在 Unix 下的安全性 (30 分钟) 1.1 问题 1 1.1.1 问题 我们注意constat到通过 SMTP 服务器发送“假”电子邮件(垃圾邮件)相对容易。越来越常见的做法是在 SMTP 连接之上部署dployer TLS 协议protocole(即 SMTPS)。这解决了垃圾…...

魔行观察-AI数据分析-蜜雪冰城
摘要 本报告旨在评估蜜雪冰城品牌作为投资对象的潜力和价值,基于其经营模式、门店分布、人均消费、覆盖省份等关键指标进行分析。 数据数据源:魔行观察:http://www.wmomo.com/#/brand/brandDetails?code10013603 品牌概览 蜜雪冰城是中国…...
如何在CSS中设置px值
在CSS中设置px(像素)值非常简单。px是CSS中最常用的长度单位之一,用于指定元素的大小、位置、间距等。 以下是一些示例,展示如何在CSS中使用px值: 设置元素宽度和高度 css复制代码 .box { width: 200px; /* 设置元素…...
【linux】find命令详解
Linux中的find命令用于在文件系统中搜索符合条件的文件或目录。 一.基本语法 find [path] [expression] #path:搜索的起始目录,如果不指定,默认为当前目录 #expression:定义搜索条件的表达式 命令选项 -name 按文件名搜索 -size …...
Android音频管理器探索与应用
在Android应用开发中,音频管理器是一个至关重要的组件,它负责处理设备的音频功能,包括音量控制、音频路由、音效处理以及与其他应用的音频交互。本文将深入探讨Android音频管理器的功能和应用,帮助开发者更好地理解和利用这一关键…...
qt QTreeWidget文件管理器拖入应用,从应用拖入文件管理器拷贝
我用QT实现了一个文件管理的软件,能够实现从桌面或其他路径拖拽文件到软件,软件获取拖拽文件的路径。但是当我想实现反向操作时遇到了问题。在网上搜索和阅读文档一天多都未能解决该问题。 下面给出我的实现: Qt开发中经常会用QTreeWidget去…...

Qt中使用MySQL数据库详解,好用的模块类封装
本文将详细介绍如何在Qt应用程序中集成MySQL数据库,并封装实现好用的mysql数据库操作类。包括环境准备、连接数据库、执行查询及异常处理等关键步骤,同时包含mysql驱动的编译。分享给有需要的小伙伴,喜欢的可以点击收藏。 目录 环境准备 项…...
C语言实现 人生重生模拟器游戏
目录 实现一个简化版的人生重开模拟器 1.菜单函数 2.game函数 3.幼年时期(even函数) 4.壮年时期(Juvenile函数) 课余时间实现的小游戏 实现一个简化版的人生重开模拟器 1.菜单函数 void menu() {printf("---------------…...
C语言两个较大数字相加
C语言两个较大数字相加 思路分析 由于C语言中的基本数据类型(如int、long等)有固定的大小,无法直接处理非常大的数字(如数百位的数字)。因此,我们需要采用字符串或数组来表示大数字,并逐位进行…...
大数据面试题之Flume
目录 介绍下Flume Flume架构 Flume有哪些Source 说下Flume事务机制 介绍下Flume采集数据的原理?底层实现? Flume如何保证数据的可靠性 Flume传输数据时如何保证数据一致性(可靠性) Flume拦截器 如何监控消费型Flu…...
js文件的执行和变量初始化缓存
js文件和变量初始化 全局变量举例js文件加载 全局变量举例 import * as turf from "turf/turf"; import earcut from "earcut"; import * as THREE from "three"; import { TextGeometry } from "three/addons/geometries/TextGeometry.js…...

无法定位程序输入点Z9 qt assertPKcS0i于动态链接库F:\code\projects\06_algorithm\main.exe
解决方法: 这个报错,是因为程序在运行时没要找到所需的dll库,如果把这个程序方法中对应库的目录下执行,则可正常执行。即使将图中mingw_64\bin 环境变量上移到msvc2022_64\bin 之前也不可以。 最终的解决方法是在makefile中设置环…...

GoLand 2024 for Mac GO语言集成开发工具环境
Mac分享吧 文章目录 效果一、下载软件二、开始安装1、双击运行软件(适合自己的M芯片版或Intel芯片版),将其从左侧拖入右侧文件夹中,等待安装完毕2、应用程序显示软件图标,表示安装成功3、打开访达,点击【文…...
Protocol Buffer 基础(c++)
本教程提供了使用协议缓冲区的基本介绍。通过逐步创建一个简单的示例应用程序,介绍以下内容: 1.在.proto文件中定义消息格式。 2.使用 protocol buffer 编译器。 3.使用c protocol buffer API来写入和读取消息。 一、问题描述 将要使用的示例是…...

上位机网络通讯
目录 一 设计原型 二 后台源码 一 设计原型 二 后台源码 using System; using System.Net.Sockets; using System.Text; using System.Threading.Tasks; using System.Windows.Forms;namespace 上位机网络通讯 {public partial class Form1 : Form{public Form1(){Initializ…...

手游刚开服就被攻击怎么办?如何防御DDoS?
开服初期是手游最脆弱的阶段,极易成为DDoS攻击的目标。一旦遭遇攻击,可能导致服务器瘫痪、玩家流失,甚至造成巨大经济损失。本文为开发者提供一套简洁有效的应急与防御方案,帮助快速应对并构建长期防护体系。 一、遭遇攻击的紧急应…...
PHP和Node.js哪个更爽?
先说结论,rust完胜。 php:laravel,swoole,webman,最开始在苏宁的时候写了几年php,当时觉得php真的是世界上最好的语言,因为当初活在舒适圈里,不愿意跳出来,就好比当初活在…...
Cesium1.95中高性能加载1500个点
一、基本方式: 图标使用.png比.svg性能要好 <template><div id"cesiumContainer"></div><div class"toolbar"><button id"resetButton">重新生成点</button><span id"countDisplay&qu…...
STM32+rt-thread判断是否联网
一、根据NETDEV_FLAG_INTERNET_UP位判断 static bool is_conncected(void) {struct netdev *dev RT_NULL;dev netdev_get_first_by_flags(NETDEV_FLAG_INTERNET_UP);if (dev RT_NULL){printf("wait netdev internet up...");return false;}else{printf("loc…...

理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端
🌟 什么是 MCP? 模型控制协议 (MCP) 是一种创新的协议,旨在无缝连接 AI 模型与应用程序。 MCP 是一个开源协议,它标准化了我们的 LLM 应用程序连接所需工具和数据源并与之协作的方式。 可以把它想象成你的 AI 模型 和想要使用它…...

深入理解JavaScript设计模式之单例模式
目录 什么是单例模式为什么需要单例模式常见应用场景包括 单例模式实现透明单例模式实现不透明单例模式用代理实现单例模式javaScript中的单例模式使用命名空间使用闭包封装私有变量 惰性单例通用的惰性单例 结语 什么是单例模式 单例模式(Singleton Pattern&#…...

高等数学(下)题型笔记(八)空间解析几何与向量代数
目录 0 前言 1 向量的点乘 1.1 基本公式 1.2 例题 2 向量的叉乘 2.1 基础知识 2.2 例题 3 空间平面方程 3.1 基础知识 3.2 例题 4 空间直线方程 4.1 基础知识 4.2 例题 5 旋转曲面及其方程 5.1 基础知识 5.2 例题 6 空间曲面的法线与切平面 6.1 基础知识 6.2…...
LLM基础1_语言模型如何处理文本
基于GitHub项目:https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken:OpenAI开发的专业"分词器" torch:Facebook开发的强力计算引擎,相当于超级计算器 理解词嵌入:给词语画"…...
C++八股 —— 单例模式
文章目录 1. 基本概念2. 设计要点3. 实现方式4. 详解懒汉模式 1. 基本概念 线程安全(Thread Safety) 线程安全是指在多线程环境下,某个函数、类或代码片段能够被多个线程同时调用时,仍能保证数据的一致性和逻辑的正确性…...
Java线上CPU飙高问题排查全指南
一、引言 在Java应用的线上运行环境中,CPU飙高是一个常见且棘手的性能问题。当系统出现CPU飙高时,通常会导致应用响应缓慢,甚至服务不可用,严重影响用户体验和业务运行。因此,掌握一套科学有效的CPU飙高问题排查方法&…...