C语言——扫雷小游戏

        扫雷小游戏:

游戏最终效果:

1.先写一下游戏开始的简单界面。

用一个函数来写一下

void menu()
{printf(" ---------------------------- \n");printf("|           1.play           |\n");printf("|           0.exit           |\n");printf(" ---------------------------- \n");}

这里的功能(说明):

        输入 1  代表游戏开始;

        输入 0  代表游戏结束,并退出页面;

既然写扫雷,那地图中的地雷应该是随机出现的,那我们可以用一个srand函数让它随机出现生成地雷。

            srand((unsigned int)time(NULL));   //生成随机数的一个函数

具体用法可以百度一下,简单的概括就是生成一个随机数字。

int main()
{srand((unsigned int)time(NULL));int input = 0;    //用与while函数循环的选择do {              //也就是刚开始说的界面选择开始或结束的选项menu();printf("请选择>");        scanf("%d", &input);   //这里的input就是游戏开始或结束的选择switch (input)         //再循环里面嵌套一个switch  {case 1:                 //   当输入1的时候,那就进入游戏开始的逻辑printf("游戏开始!\n");system("cls");      // :这里是系统函数,用于清空控制台的消息与文字game();             //  这个是游戏开始的函数接口break;case 0:                 //   当选择0的时候,即退出游戏退出循环,并程序结束。printf("\n即将退出游戏!\n");break;default :              //因为只有输入0/1,否则就是输入错误,需要重新输入printf("您的选择有误,请重新输入:\n");}} while (input);return 0;
}

当我们选择play时,我们将进入游戏,之后就是游戏逻辑的代码了。

#define ROW 9   //棋盘  行
#define COL 9	//棋盘  列
#define ROWS ROW+2	//判断-棋盘  行
#define COLS COL+2  //判断-棋盘  列
#define COUNT 10	//地雷个数

扫雷,我们需要创建两个二维数组,之后的操作与逻辑都是围绕这两个棋盘来写

一个用来展示覆盖与否的画面(代码中的  show数组):

一个用来记载着地雷的位置与判断(代码中的mine数组) :

void game() 
{char mine[ROWS][COLS];    //注: ROWS COLS  为头文件define出来的行和列char show[ROWS][COLS];//初始化数据 Initboard(mine, ROWS, COLS, '0');Initboard(show, ROWS, COLS, '*');//棋盘打印Displayboard(show, ROW, COL);//布置雷Setmine(mine, ROW, COL);//排查雷Findmine(mine, show, ROW, COL);//Displayboard(show, ROW, COL);}

     之后我们需要先把两个二维数组给初始化一下:

这里我们写一个函数Initboard

//初始化棋盘
void Initboard(char borad[ROWS][COLS], int rows, int cols,char set)
{int i = 0;for (i = 0; i < rows; i++){for (int j = 0; j < cols; j++){borad[i][j] = set;}}
}

我们将mine的二维数组都初始化为’0‘

        将show二维数组都初始化为’*‘

注:我们展示出来的一般都是show的二维数组
 

所以我们需要写一个格式函数

//打印棋盘   //并设置格式
void Displayboard(char borad[ROWS][COLS], int row, int col)
{printf("======扫雷游戏======\n");int i = 0;for (i = 0; i <= row; i++){printf("%d ", i);}printf("\n");for (int a = 1; a <=row; a++){	printf("%d ", a);for (int b = 1; b <= col; b++){Sleep(10);printf("%c ", borad[a][b]);}printf("\n");}printf("======扫雷游戏======\n");}

展示出来就是这个样子。

游戏页面的大概就展示出来了,接下来我们需要写一下游戏判断逻辑了

首先我们需要埋雷,但雷的位置是随机的,所以我们需要用一下srand函数,把雷随机的放进mine二维数组中,就是随机生成一个坐标

        注:mine二维数组中 “0”代表该位置是安全的坐标

                                         “1”代表该位置是埋有地雷的坐标)

//布置雷
void Setmine(char mine[ROWS][COLS], int row, int col)
{int count = COUNT;    //COUNT代表的雷的个数,可以自己设置while (count){int x = rand() % row + 1;        //随机生成x坐标int y = rand() % col + 1;        //随机生成y坐标if (mine[x][y] =='0')    {mine[x][y] = '1';            //把mine二维数组的该位置改为1count--;}                                //代表着埋入地雷}
}

接下来就是输入坐标来排查雷的步骤了

//排查雷 
void Findmine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{int a = 0;int b= 0;int win = 0;
while(win<row*col-COUNT){                     printf("请输入您的坐标:");scanf("%d", &a);            //输入坐标x和yscanf("%d", &b);if ((a <= row + 1 && a > 0) && (b <= col + 1 && b > 0))   {        //这里需要用if来判断一下x和y的值是否大于坐标,不在这个范围就需要重新输入坐标if (mine[a][b] == '1')    //这里判断的是如果坐标刚好在雷的位置,游戏就结束了{system("cls");    //清空屏幕printf("很抱歉,您被炸死了。\n");Displayboard(mine, ROW, COL);       //当炸死后,这里在打印一下mine的棋盘Sleep(1000);                        //提示一下并答应雷的位置告诉玩家这里是雷break;            //游戏结束后这里需要break一下结束这一层的循环}else{	int count=Getminecount(mine,a,b);//Getminecount函数排查这个坐标周围有多少颗雷show[a][b] = count+'0';system("cls");Displayboard(show, ROW, COL);win++;}}else        //当不在取值范围内就需要重新输入一下  并输出一个坐标有误的提示{printf("您输入的坐标有误,请重新输入:\n ");}}if (win == row * col - COUNT)    当把雷的排完后,就获胜了!{printf("恭喜你,排雷成功。\n");Displayboard(show, ROW, COL);}
}

 该函数用于统计坐标周围有多少颗雷。

//统计周围雷的个数
int Getminecount(char mine[ROWS][COLS], int x, int y)
{return (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] +mine[x - 1][y] - 8 * '0');
}

下面是全代码: 

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#include<windows.h>
#define ROW 9   //棋盘  行
#define COL 9	//棋盘  列
#define ROWS ROW+2	//判断-棋盘  行
#define COLS COL+2  //判断-棋盘  列#define COUNT 10	//地雷个数//初始化棋盘
void Initboard(char borad[ROWS][COLS], int rows, int cols,char set)
{int i = 0;for (i = 0; i < rows; i++){for (int j = 0; j < cols; j++){borad[i][j] = set;}}
}//打印棋盘   //并设置格式
void Displayboard(char borad[ROWS][COLS], int row, int col)
{printf("======扫雷游戏======\n");int i = 0;for (i = 0; i <= row; i++){printf("%d ", i);}printf("\n");for (int a = 1; a <=row; a++){	printf("%d ", a);for (int b = 1; b <= col; b++){Sleep(10);printf("%c ", borad[a][b]);}printf("\n");}printf("======扫雷游戏======\n");}//布置雷
void Setmine(char mine[ROWS][COLS], int row, int col)
{int count = COUNT;while (count){int x = rand() % row + 1;int y = rand() % col + 1;if (mine[x][y] =='0'){mine[x][y] = '1';count--;}}
}//排查雷 
void Findmine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{int a = 0;int b= 0;int win = 0;
while(win<row*col-COUNT){printf("请输入您的坐标:");scanf("%d", &a);scanf("%d", &b);//	a = a / a * a;//	b = b / b * b;if ((a <= row + 1 && a > 0) && (b <= col + 1 && b > 0)){if (mine[a][b] == '1'){system("cls");printf("很抱歉,您被炸死了。\n");Displayboard(mine, ROW, COL);Sleep(1000);break;}else{	int count=Getminecount(mine,a,b);show[a][b] = count+'0';system("cls");Displayboard(show, ROW, COL);win++;}}else{printf("您输入的坐标有误,请重新输入:\n ");}}if (win == row * col - COUNT){printf("恭喜你,排雷成功。\n");Displayboard(show, ROW, COL);}
}//统计周围雷的个数
int Getminecount(char mine[ROWS][COLS], int x, int y)
{return (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] +mine[x - 1][y] - 8 * '0');}void menu()
{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(mine, ROW, COL);Displayboard(show, ROW, COL);//布置雷Setmine(mine, ROW, COL);//排查雷Findmine(mine, show, ROW, COL);//Displayboard(show, ROW, COL);}
int main()
{srand((unsigned int)time(NULL));int input = 0;do {menu();printf("请选择>");scanf("%d", &input);switch (input){case 1:printf("游戏开始!\n");Sleep(1000);system("cls");game();break;case 0:printf("\n即将退出游戏!\n");break;default :printf("您的选择有误,请重新输入:\n");}} while (input);return 0;
}

 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SSM图书借阅管理系统-计算机毕业设计源码06780

摘 要 大数据时代下&#xff0c;数据呈爆炸式地增长。为了迎合信息化时代的潮流和信息化安全的要求&#xff0c;利用互联网服务于其他行业&#xff0c;促进生产&#xff0c;已经是成为一种势不可挡的趋势。在图书馆的要求下&#xff0c;开发一款整体式结构的图书借阅管理系统&a…

valgrind工具的交叉编译及使用

一 概述 valgrind是一款非常好用的工具&#xff0c;用于检测内存泄漏等&#xff0c;这里讲述如何将其交叉编译到arm开发板及如何使用 【C/C 集成内存调试、内存泄漏检测和性能分析的工具 Valgrind 】Linux 下 Valgrind 工具的全面使用指南 - 知乎 (zhihu.com) valgrind: fai…

Python武器库开发-武器库篇之文件上传漏洞扫描器(六十二)

Python武器库开发-武器库篇之文件上传漏洞扫描器&#xff08;六十二&#xff09; 文件上传漏洞简介以及危害 文件上传漏洞是指在网站或应用程序中&#xff0c;攻击者可以通过合法的文件上传功能&#xff0c;由于对用户上传的文件没有进行严格的验证和过滤&#xff0c;导致攻击…

机器学习_SVM支持向量机

引入&#xff1a;在面对线性可分时&#xff0c;即用一条直线就可以区分数据的时候&#xff0c;需要将直线放在距离数据点距离最大化的位置&#xff0c;这个过程需要寻找最大间隔&#xff0c;即为最优化问题。当数据点不能用一根直线区分——线性不可分&#xff0c;就需要用核函…

免费Syslog日志接收工具

如果您想知道您的网络中发生了什么&#xff0c;以便洞察潜在的威胁并在它们变成攻击之前阻止它们&#xff0c;那么您需要查看您的日志。Syslog日志是网络设备、操作系统和应用程序生成的一种重要日志数据&#xff0c;通过有效地收集和监视Syslog日志&#xff0c;企业可以及时发…

设计模式(七)创建者模式之建造者模式

这里写目录标题 概述需求需求类图BikeBuilderMobikeBuilderOfoBuilderDirectorClientClient优缺点使用场景 模式扩展ComputerClient创建者模式对比工厂方法模式VS建造者模式抽象工厂模式VS建造者模式 总结 概述 建造者模式又叫生成器模式&#xff0c;是一种对象构建模式。它可…

Vue3中的常见组件通信之插槽

Vue3中的常见组件通信之插槽 概述 ​ 在vue3中常见的组件通信有props、mitt、v-model、 r e f s 、 refs、 refs、parent、provide、inject、pinia、slot等。不同的组件关系用不同的传递方式。常见的撘配形式如下表所示。 组件关系传递方式父传子1. props2. v-model3. $refs…

音频处理软件adobe audition使用教程

教程1笔记 基本操作 点击文件-》新建-》多轨会话&#xff1a; 编辑-》首选项&#xff0c;设置自动保存时间&#xff1a; 导入素材&#xff0c;文件-》导入素材&#xff0c;或者直接拖动进来文件&#xff01; 导出多轨混音&#xff1a; 更改为需要导出的格式wav,mp3等格式&am…

矿用行程位移传感器传感器ZE0701-06CU

矿用行程传感器概述 矿用行程传感器是一种专为煤矿等特定环境设计的传感器&#xff0c;用于监测和测量设备或部件的位移量。它们通常用于液压支架、千斤顶、掘进机等矿山设备中&#xff0c;帮助监测和控制设备的运动状态&#xff0c;以确保安全和高效的生产。 定义和功能 矿用…

微信小程序入门1

什么是微信小程序&#xff1f; 与传统的原生应用相比&#xff0c;微信小程序是一种全新的连接用户与服务的应用&#xff0c;它可以在微信内被便捷地获取和传播&#xff0c;同时具有良好的用户体验。微信小程序是运行在微信中的应用&#xff0c;是一种不需要下载即可使用的应用…

食品企业仓储式批发零售一体化解决方案

食品企业需要有效应对日益复杂的市场挑战和消费者需求的快速变化的挑战并提升市场竞争力&#xff0c;仓储式类的批发零售一体化需求应运而生。这一全新的商业模式不仅整合了传统的批发和零售模式&#xff0c;还优化了供应链管理和客户体验&#xff0c;成为食品行业发展的新引擎…

哈希的基本原理

目录 一.哈希概念 二.哈希冲突 三.哈希函数 四.哈希冲突解决 一.闭散列(开放寻址法) ①插入&#xff1a; ②查找&#xff1a; ③删除&#xff1a; 代码测试&#xff1a; 二.开散列(拉链法) ①插入&#xff1a; ②查找&#xff1a; ③删除&#xff1a; 代码测试&a…

Linux终端玩转bastet俄罗斯方块小游戏

Linux终端玩转bastet俄罗斯方块小游戏 一、bastet小游戏介绍1.1 bastet小游戏简介1.2 项目预览 二、本次实践介绍2.1 本地环境规划2.2 本次实践介绍 三、检查系统镜像源3.1 检查系统镜像源3.2 更新软件列表3.3 查询软件 四、安装bastet小游戏4.1 安装bastet4.2 启动bastet游戏 …

基本公式汇总

高等数学公式汇总 一、三角函数公式 1、特殊值 2、二倍角和差公式 1&#xff09;正余弦和差公式 2&#xff09;正切和差公式 3&#xff09;积化和差 4&#xff09;和差化积 3、平方和公式 4、倍角公式 5、半角公式 6、万能公式 7、辅助角公式 二、反三角函数公式 1、余角关…

宁德时代华北首座电池工厂在北京开工

6月18日&#xff0c;由宁德时代与北汽集团、京能集团、小米集团等共同投资建设的北京时代电池基地项目开工仪式在北京举行。 北京市相关政府代表&#xff0c;宁德时代董事长兼CEO曾毓群&#xff0c;北汽集团董事长张建勇&#xff0c;京能集团副总经理张凤阳&#xff0c;小米集…

GaussDB技术解读——GaussDB架构介绍(五)

GaussDB架构介绍&#xff08;四&#xff09;从云原生关键技术架构&关键技术方案两方面对GaussDB云原生架构进行了解读&#xff0c;本篇将从关键技术方案的事务存储组件、SQL引擎组件、DCS组件、实时分析组件等方面继续介绍GaussDB云原生架构。 目录 事务存储组件 1、本地…

NPDP含金量、考试内容、报考要求、适合人群?

01.NPDP核心价值解读 NPDP认证的核心价值在于整合产品开发管理的理论与实践&#xff0c;包含新产品开发策略、研发流程管理、市场研究、销规划、团队管理、项目管理等等&#xff0c;理论体系和知识内容穿插在产品发展的全过程。 对于职场打工人来说&#xff0c;拥有NPDP证书证…

【超越拟合:深度学习中的过拟合与欠拟合应对策略】

如何处理过拟合 由于过拟合的主要问题是你的模型与训练数据拟合得太好&#xff0c;因此你需要使用技术来“控制它”。防止过拟合的常用技术称为正则化。我喜欢将其视为“使我们的模型更加规则”&#xff0c;例如能够拟合更多类型的数据。 让我们讨论一些防止过拟合的方法。 获…

css如何动态累计数字?

导读&#xff1a;css如何动态累计数字&#xff1f;用于章节目录的序列数生成&#xff0c;用css的计数器实现起来比 js方式更简单&#xff01; 伪元素 ::after ::before伪元素设置content 可以在元素的首部和尾部添加内容&#xff0c;我们要在元素的首部添加序列号&#xff0c…

NUC 14 Pro+:解锁AI前沿,体验科技之美

NUC 14 Pro不仅是一台迷你主机&#xff0c;更是生活品质的体现。如果你也是细节控&#xff0c;那这篇文章或许是你需要的。 超小体积 造型精致 NUC 14 Pro作为迷你PC拥有约0.66L的超小体积&#xff0c;如果你对升没有概念&#xff0c;那你可以想象&#xff1a;它的机箱面积144…