C语言实现扫雷游戏完整版

游戏介绍:

目录

游戏介绍:

游戏框架:

游戏具体功能实现:

棋盘的定义:

棋盘初始化:

棋盘打印:

棋盘布置雷:

棋盘扫雷:

爆炸展开一片:

获取周围八个格子的雷数:

游戏源码:

test.c:

game.h:

game.c:


扫雷游戏相信大家都玩过,大概就是点击一个格子,如果这个格子是雷就被炸死,不是雷,就会显示周围八个格子有几个雷,如果玩家把没有雷的格子点完了就赢了。

游戏框架:

我们还是分为三个文件来写:test.c:用来写游戏整体的逻辑。game.c:写代码中最关键的部分,游戏基本功能实现的函数。game.h:写需要的头文件,常量,函数定义等。

游戏具体功能实现:

棋盘的定义:

首先第一步我们就需要知道雷盘(棋盘)是一个个格子的,所以我们就可以用二维数组来实现。我们看到扫雷游戏,有展现给玩家的雷盘,上面我们看不到哪里有雷,但是如果只有一个二维数组就无法实现,所以我们定义两个二维数组,一个展现给玩家,一个内部操作:

我们的ROWS和COLS这样子定义其一是因为方便修改,其二是因为我们展现出的棋盘要比内部棋盘少两行和两列。

为什么要这样:因为我们想到如果点击雷盘的最边上的一格,在数组上,我们得扫描周围八个格子,会越界操作,如果我们不越界,那就得加上很多限制条件,条件太多可能会把自己弄晕,所以有的大佬想出给我们的数组再加上两行和两列,这样我们依旧扫描周围八个但是就不会越界了,展现给玩家的只有内部的格子。

棋盘初始化:

因为我们有两个棋盘得放不一样的元素,所以初始化函数:

set变量就可以实现我们想让数组初始化什么就初始化什么。

所以内部棋盘都初始化为0,展现棋盘都初始化为 * 。

棋盘打印:

在这里我们就用ROW和COL来遍历棋盘,从下标1开始。

棋盘布置雷:

布置雷需要注意的:

1.只在内部格子布置

2.格子里必须是0才放,以防少放了

我们放雷的时候只需要在需要展现的棋盘上放就行了,所以 i 和 j 这两个随机值要在1——9的范围里,之所以我们用1来表示雷,后面我会解释。

棋盘扫雷:

逻辑是让玩家输入坐标,如果踩到雷了就退出告诉玩家你失败了。如果没有踩到雷,就扫描周围八个格子看有多少个雷,然后显示到格子上,如果坐标格子周围八个格子没有雷就展开周围八个格子,直到把没有雷的格子点完就算赢。

爆炸展开一片:

像这样点击一个之后爆炸式展开该怎么实现,我们是扫描坐标周围八个格子都没有雷的话就把他设成空格,如果看周围八个格子的其中一个周围也没有雷再把他设成空格,这样子可以形成函数递归,我们来实现这个递归:

获取周围八个格子的雷数:

这个时候我们把没有雷设成0,雷设成1 的简单办法就来了,如果没有这样设置,我们就要多设置判断语句。如果是 0 和 1,我们知道数组里是字符0 和 1,根据ASCLL表发现字符的1 减去 0 就是数字1了,所以我们可以把周围格子加起来再一起减去字符0 就是最终结果。

游戏源码:

test.c:

#include"game.h"void meun()
{printf("************************\n");printf("*******  1.  play ******\n");printf("*******  0.  exit ******\n");printf("************************\n");
}void game()
{char mine[ROWS][COLS];char show[ROWS][COLS];InitBoard(mine, ROWS, COLS, '0');InitBoard(show, ROWS, COLS, '*');//打印棋盘DisplayBoard(show, ROW, COL);//布置雷SetMine(mine, ROW, COL);//DisplayBoard(mine, ROW, COL);//排雷FindMine(mine, show, ROW, COL);}int main()
{srand((unsigned int)time(NULL));int input = 0;;do{meun();printf("请选择:");scanf("%d", &input);switch (input){case 1:game();break;case 0:printf("退出游戏\n");break;default:printf("输入错误,重新输入\n");break;}} while (input);
}

game.h:

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<string.h>
#include<Windows.h>#define ROW 9
#define COL 9#define ROWS ROW + 2
#define COLS COL + 2#define Easy_play 20//雷的个数//初始化棋盘
void InitBoard(char board[ROWS][COLS], int rows, int cols, char set);//打印棋盘
void DisplayBoard(char board[ROWS][COLS], int row, int col);//布置雷
void SetMine(char mine[ROWS][COLS], int row, int col);//排查雷
void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);

game.c:

#include"game.h"//初始化棋盘
void InitBoard(char board[ROWS][COLS], int rows, int cols, char set)
{for (int i = 0; i < rows; i++){for (int j = 0; j < cols; j++){board[i][j] = set;}}
}//打印棋盘
void DisplayBoard(char board[ROWS][COLS], int row, int col)
{printf("----------扫雷-------------\n");for (int i = 1; i <= row; i++){for (int j = 1; j <= col; j++){printf(" %c ", board[i][j]);}printf("\n");}printf("----------扫雷-------------\n");
}void SetMine(char mine[ROWS][COLS], int row, int col)
{int m = Easy_play;while (m){int i = rand() % row + 1;//1 --- 9int j = rand() % col + 1;//要棋盘里必须是0 的时候再放if (mine[i][j] == '0'){mine[i][j] = '1';m--;}}
}int GetMineCount(char mine[ROWS][COLS], int x, int y)
{//因为我们的棋盘里放的‘0’和‘1’所以,我们周围八个加起来就行,但是因为他们是字符,所以只要 - ‘0’,就会变成数字return mine[x - 1][y - 1] +mine[x - 1][y] +mine[x - 1][y + 1] +mine[x][y - 1] +mine[x][y + 1] +mine[x + 1][y - 1] +mine[x + 1][y] +mine[x + 1][y + 1] - 8 * '0';
}void My_FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col, int x, int y, int* pw)
{if (x >= 1 && x <= row && y >= 1 && y <= col)//要在排查范围内{int c = GetMineCount(mine, x, y);if (c == 0){(*pw)++;show[x][y] = ' ';//这个就可以把坐标变成空格,还可以防止死递归for (int i = x - 1; i <= x + 1; i++){for (int j = y - 1; j <= y + 1; j++){if (show[i][j] == '*')//限制条件,防止查过的再次查到,造成死递归。{My_FindMine(mine, show, row, col, i, j, pw);}}}}else{show[x][y] = c + '0';(*pw)++;}}
}void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{int x = 0;int y = 0;int win = 0;int* pw = &win;while (win < row * col - Easy_play){printf("请输入你的坐标:->");scanf("%d %d", &x, &y);if (x > 0 && x <= row && y > 0 && y <= col){if (mine[x][y] == '1'){system("cls");printf("你被炸死了,真遗憾\n");DisplayBoard(mine, ROW, COL);break;}else{if (show[x][y] != '*'){printf("这个坐标输入过了,请重新输入\n");continue;}else{My_FindMine(mine, show, row, col, x, y, pw);//爆炸张开一片system("cls");//清空屏幕DisplayBoard(show, ROW, COL);}}}else{printf("坐标错了,请重新输入\n");}}if (win == row * col - Easy_play){printf("恭喜你,游戏被你结束了\n");}
}

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

ICode国际青少年编程竞赛- Python-4级训练场-绿色飞板1

ICode国际青少年编程竞赛- Python-4级训练场-绿色飞板1 1、 while Flyer.disappear():wait() Dev.step(4)2、 Dev.turnRight() Dev.step()while Flyer[0].disappear():wait() Dev.step(3) Dev.turnLeft() Dev.step() while Flyer[1].disappear():wait() Dev.step(2) Dev.tu…

每日两题 / 226. 翻转二叉树 98. 验证二叉搜索树(LeetCode热题100)

226. 翻转二叉树 - 力扣&#xff08;LeetCode&#xff09; 以后续遍历的方式交换当前节点的左右指针 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), ri…

基于DRP的增强视觉和空间感知系统

二维码图像处理算法 首先&#xff0c;先进行灰度转化&#xff0c;然后高斯滤波&#xff0c;自适应阈值二值化&#xff0c;连通域查找&#xff0c;多边形拟合和角点检测。得到二维码的正方形轮廓。 通过调用DRP协处理器加速处理&#xff0c;以识别运动中的二维码 此时&#xf…

java spring 10 Bean的销毁过程 上 在docreatebean中登记要销毁的bean

1.Bean销毁是发送在Spring容器关闭过程中的 AnnotationConfigApplicationContext context new AnnotationConfigApplicationContext(AppConfig.class);UserService userService (UserService) context.getBean("userService");userService.test();// 容器关闭cont…

【深度学习Labelme】使用Segment Anything Model (SAM)快速打标,labelme多边形转yolo txt框看看对不对

文章目录 windows安装环境打开labelme自动保存勾选上&#xff0c;保存图片数据不要勾选选SAM精准模型&#xff0c;然后打开图片路径&#xff0c;然后点击创建AI多边形&#xff1a;鼠标点击确认物体控制点&#xff0c;确认完成后&#xff0c;双击鼠标完成选取&#xff0c;并给上…

python之并发编程

python之并发编程 线程的创建方式线程的创建方式(方法包装)线程的创建方式(类包装)join()【让主线程等待子线程结束】守护线程【主线程结束&#xff0c;子线程就结束】 锁多线程操作同一个对象(未使用线程同步)多线程操作同一个对象(增加互斥锁&#xff0c;使用线程同步)死锁案…

P9420 [蓝桥杯 2023 国 B] 子 2023 / 双子数

蓝桥杯2023国B A、B题 A题 分析 dp问题 根据子序列&#xff1a;2&#xff0c;20&#xff0c;202&#xff0c;2023分为4个状态&#xff1b; 当前数字为2时&#xff0c;处于dp[0]&#xff0c;或者和dp[1]结合成dp[2]&#xff1b; 当前数字为0时&#xff0c;和dp[0]结合成dp[…

什么是SOL链跟单机器人与阻击机器人?

SOL链作为一个快速增长的区块链生态系统&#xff0c;为各种应用程序提供了丰富的发展机会。在SOL链上&#xff0c;智能合约的应用已经开始蓬勃发展&#xff0c;其中包括了许多与加密货币交易相关的应用。在本文中&#xff0c;我们将介绍在SOL链上开发的阻击机器人&#xff08;S…

【二叉树算法题记录】二叉树的所有路径,路径总和——回溯

目录 257. 二叉树的所有路径题目描述题目分析cpp代码 112. 路径总和题目描述题目分析cpp代码 257. 二叉树的所有路径 题目描述 给你一个二叉树的根节点root &#xff0c;按任意顺序&#xff0c;返回所有从根节点到叶子节点的路径。 题目分析 其实从根节点往下走&#xff0c…

Mat: Unknown HPROF Version

问题&#xff1a;Mat 加载 android studio 导出的 hprof 文件失败 原因&#xff1a;android hprof 文件不是标准的 java hprof 文件 解决办法&#xff1a; 使用 android sdk 自带的命令将 hprof 转换成标准的 java hprof

替代UCC21550隔离式双通道栅极驱动器

描述 PC86320是一个隔离的双通道栅极驱动器具有可编程死区时间和宽温度范围。它设计有5A峰值源和6A峰值吸收电流来驱动电源高达2MHz的MOSFET、SiC、GaN和IGBT晶体管开关频率。PC86320可以配置为两个低端驱动器&#xff0c;两个高边驱动器&#xff0c;或具有可编程功能的半桥驱…

JavaScript数组(Array)方法 - toReversed、toSorted、toSpliced

最近发现几个数组方法&#xff0c;是一些常规方法的升级版&#xff0c;比较有意思&#xff0c;分享给大家 文章目录 一、温故二、知新toReversedtoSortedtoSpliced 一、温故 我们先来回顾几个比较常用的方法&#xff1a;reverse&#xff0c;sort&#xff0c;splice众所周知&a…

【HMGD】GD32/STM32 DMA接收不定长串口数据

单片机型号&#xff1a;GD32F303系列 CubeMX配置 配置串口参数 开启DMA 开启中断 示例代码 使用到的变量 uint8_t RX_Buff_FLAG 0; uint8_t RX_Buff[300] {0}; uint8_t TX_Buff[300] {0};串口接收空闲函数 // 串口接收空闲函数 void HAL_UARTEx_RxEventCallback(UART_H…

深入理解Java HashSet类及其实现原理

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。运营社区&#xff1a;C站/掘金/腾讯云&#xff1b;欢迎大家常来逛逛 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一…

伦敦金交易常识 原来可以这样分类

如果投资者想做好伦敦金交易&#xff0c;对市场中的伦敦金交易常识等等都需要加以学习和研究&#xff0c;别小看那些伦敦金交易常识&#xff0c;很多高深的交易策略也是从常识出发慢慢建立起来的。伦敦金交易常识可以分为几类&#xff0c;下面我们就来讨论一下。 伦敦金市场的基…

OpenNJet,够轻更强云原生应用引擎

前言&#xff1a; 在正式介绍OpenNJet之前&#xff0c;我们先来看看它的技术架构&#xff0c;如下图所示&#xff0c;OpenNJet正是NGINX的Pro版&#xff0c;在100%兼容NGINX基础上&#xff0c;新增了动态配置加载、主动式健康检测、集群高可用、声明式API等多种强大功能。 NGIN…

FLEX组件可视化设计器CSS3代码生成器

Flex布局可以简便、完整、响应式地实现各种页面布局&#xff0c;所以本软件研发出来FLEX组件。Flex组件是本软件布局的核心&#xff0c;只有掌握好flex组件布局&#xff0c;你才能打造出优秀的个性化页面。 设计完成后整个布局及CSS样式代码都会生成。 排列方向flex-direction…

GPT+Python近红外光谱数据分析

原文链接&#xff1a;GPTPython近红外光谱数据分析https://mp.weixin.qq.com/s?__bizMzUzNTczMDMxMg&mid2247603913&idx1&sn6eb8fd6f1abcdd8160815997a13eb03d&chksmfa82172ecdf59e389a860547a238bb86c7f38ae3baa14e97c7490a52ef2a2c206f88d503a5eb&token…

《星河战队4:星际觉醒》(上)AI科幻电影欣赏

《星河战队4&#xff1a;星际觉醒》&#xff08;上&#xff09;AI科幻电影欣赏 征服与荣耀&#xff0c;贪婪与救赎&#xff0c;浩瀚宇宙&#xff0c;人类终将灭绝&#xff1f; 《星河战队4&#xff1a;星际觉醒》&#xff08;上&#xff09;在未来世界&#xff0c;随着星际探索…

使用LangChain和Neo4j快速创建RAG应用

大家好&#xff0c;Neo4j 通过集成原生的向量搜索功能&#xff0c;增强了其对检索增强生成&#xff08;RAG&#xff09;应用的支持&#xff0c;这标志着一个重要的里程碑。这项新功能通过向量索引搜索处理非结构化文本&#xff0c;增强了 Neo4j 在存储和分析结构化数据方面的现…