C语言第十课----------------扫雷----------数组的经典练手题

作者前言

🎂        ✨✨✨✨✨✨🍧🍧🍧🍧🍧🍧🍧🎂

   🎂      作者介绍:                              🎂🎂

       🎂 🎉🎉🎉🎉🎉🎉🎉              🎂

          🎂作者id:老秦包你会,         🎂

简单介绍:🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂

             喜欢学习C语言和python等编程语言,是一位爱分享的博主,有兴趣的小可爱可以来互讨         🎂🎂🎂🎂🎂🎂🎂🎂

                 🎂个人主页::小小页面🎂

                  🎂gitee页面:秦大大🎂

                   🎂🎂🎂🎂🎂🎂🎂🎂
        🎂  一个爱分享的小博主 欢迎小可爱们前来借鉴🎂

_______________________________________________________

______________________________________________________________________

目录

扫雷

        分析

        代码

——————————————————————————————————————

扫雷

 如上图,玩扫雷的原理就是避开雷找出所有的雷就胜利,废话不多说,我们直接开始扫雷分析

分析

俗话说的好,玩游戏第一步进入游戏,我们就写出一个游戏菜单出来,让玩家选择

void meun()
{printf("*********        扫雷       ********\n");printf("************************************\n");printf("*********       0.exit      ********\n");printf("*********       1.paly      ********\n");printf("************************************\n");}

下面我们要写一个框架,选择玩或者不玩,

int input;srand((unsigned)time(NULL));do{meun();printf("进入扫雷界面,请选择>");scanf("%d", &input);switch (input){case 0:printf("退出游戏\n");break;case 1:printf("开始游戏\n");game();break;default :printf("输入不符合规定,请重新输入\n");break;}

下面我们就要开始写扫雷的内容了,首先扫雷我们要给出扫雷的游戏画面,在这个过程中我们可以创建两个数组,一个用于计算,一个用于显示

 左边是计算,右边是显示 然后我们就要设计一下输出的界面,要玩家有好的体验

void initialization(char mine[ROWS][COLS], int rows, int cols, char str)
{int i = 0;for (i = 0; i < rows; i++){int j = 0;for (j = 0; j < cols; j++){mine[i][j] = str;}}}
void Carving(char mine[ROWS][COLS], int row, int col)
{int i = 0;for (i = 0; i <= row; i++){printf("%d ", i);}printf("\n");printf("--------------------\n");for (i = 1; i <= row; i++){printf("%d|", i);int j = 0;for (j = 1; j <= col; j++){printf("%c ", mine[i][j]);}printf("\n");}
}

然后我们就要布置雷了,雷的设计要随机可以使用rand(),记得设计出源点srand((unsigned)time(NULL))

代码如下:

void Production(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 paly_mine(char mine[ROWS][COLS], char show_mine[ROWS][COLS], int row, int col)
{int count = 0;int x = 0;int y = 0;while (1){printf("请玩家输入坐标:>");scanf("%d %d", &x, &y);if (x >= 1 && x <= 9 && y >= 1 && y <= 9){if (mine[x][y] == '0'){mine[x][y] = ' ';count++;//统计周边的雷数int sum = 0;int i = x - 1;for (i = x - 1; i <= x + 1; i++){int j = y - 1;for (j = y - 1; j <= y + 1; j++){if (i != x && j != y)sum = sum + (mine[i][j] - '0');}}show_mine[x][y] = '0' + sum;printf("扫雷情况:\n");Carving(show_mine, ROW, COL);printf("\n");if (count == (row * col) - Count){printf("你胜利了\n");goto  aa;}}else if (mine[x][y] == '1'){printf("你被炸死了,游戏结束\n");break;}}else{printf("请重新输入,你输入的不符合规定\n");}}
aa:;}

 下面是全部代码:

扫雷.c

#include"扫雷.h"
void meun()
{printf("*********        扫雷       ********\n");printf("************************************\n");printf("*********       0.exit      ********\n");printf("*********       1.paly      ********\n");printf("************************************\n");}
int main()
{int input;srand((unsigned)time(NULL));do{meun();printf("进入扫雷界面,请选择>");scanf("%d", &input);switch (input){case 0:printf("退出游戏\n");break;case 1:printf("开始游戏\n");game();break;default :printf("输入不符合规定,请重新输入\n");break;}} while (input);return 0;
}

扫雷函数.c

#include"扫雷.h"
void game()
{char mine[ROWS][COLS];char show_mine[ROWS][COLS];//数组初始化initialization(mine, ROWS, COLS, '0');initialization(show_mine, ROWS, COLS, '*');//布置雷Production(mine, ROW, COL);//雕刻扫雷棋盘Carving(mine, ROW, COL);printf("\n");Carving(show_mine, ROW, COL);//玩家扫雷paly_mine(mine, show_mine, ROW, COL);/*printf("%p", &mine);printf("%p", &show_mine);*/}void initialization(char mine[ROWS][COLS], int rows, int cols, char str)
{int i = 0;for (i = 0; i < rows; i++){int j = 0;for (j = 0; j < cols; j++){mine[i][j] = str;}}}void Carving(char mine[ROWS][COLS], int row, int col)
{int i = 0;for (i = 0; i <= row; i++){printf("%d ", i);}printf("\n");printf("--------------------\n");for (i = 1; i <= row; i++){printf("%d|", i);int j = 0;for (j = 1; j <= col; j++){printf("%c ", mine[i][j]);}printf("\n");}
}
//布置雷
void Production(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 paly_mine(char mine[ROWS][COLS], char show_mine[ROWS][COLS], int row, int col)
{int count = 0;int x = 0;int y = 0;while (1){printf("请玩家输入坐标:>");scanf("%d %d", &x, &y);if (x >= 1 && x <= 9 && y >= 1 && y <= 9){if (mine[x][y] == '0'){mine[x][y] = ' ';count++;//统计周边的雷数int sum = 0;int i = x - 1;for (i = x - 1; i <= x + 1; i++){int j = y - 1;for (j = y - 1; j <= y + 1; j++){if (i != x && j != y)sum = sum + (mine[i][j] - '0');}}show_mine[x][y] = '0' + sum;printf("扫雷情况:\n");Carving(show_mine, ROW, COL);printf("\n");if (count == (row * col) - Count){printf("你胜利了\n");goto  aa;}}else if (mine[x][y] == '1'){printf("你被炸死了,游戏结束\n");break;}}else{printf("请重新输入,你输入的不符合规定\n");}}
aa:;}

扫雷.h

#include<stdio.h>
#include<stdlib.h>
#include<time.h>#define ROW 9
#define COL 9
#define ROWS ROW + 2
#define COLS COL + 2
#define Count 10
//
void game(void);
//初始化
void initialization(char mine[ROWS][COLS], int row, int col, char str);
//打印棋盘
void Carving(char mine[ROWS][COLS], int row, int col);
//布置雷
void Production(char mine[ROWS][COLS], int row, int col);
//玩家扫雷
vo

总结:

扫雷代码就在这里了,这个代码还可以进一步改进,但是由于时间原因,其他功能没写,有不懂的小可啊可以私聊我

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

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

相关文章

React构建的JS优化思路

背景 之前个人博客搭建时&#xff0c;发现页面加载要5s才能完成并显示 问题 React生成的JS有1.4M&#xff0c;对于个人博客服务器的带宽来说&#xff0c;压力较大&#xff0c;因此耗费了5S的时间 优化思路 解决React生成的JS大小&#xff0c;因为我用的是react-router-dom…

prometheus告警发送组件部署

一、前言 要实现Prometheus的告警发送需要通过alertmanager组件&#xff0c;当prometheus触发告警策略时&#xff0c;会将告警信息发送给alertmanager&#xff0c;然后alertmanager根据配置的策略发送到邮件或者钉钉中&#xff0c;发送到钉钉需要安装额外的prometheus-webhook…

模拟实现消息队列(以 RabbitMQ 为蓝本)

目录 1. 需求分析1.1 介绍一些核心概念核心概念1核心概念2 1.2 消息队列服务器&#xff08;Broker Server&#xff09;要提供的核心 API1.3 交换机类型1.3.1 类型介绍1.3.2 转发规则&#xff1a; 1.4 持久化1.5 关于网络通信1.5.1 客户端与服务器提供的对应方法1.5.2 客户端额外…

【LangChain概念】了解语言链️:第2部分

一、说明 在LangChain的帮助下创建LLM应用程序可以帮助我们轻松地链接所有内容。LangChain 是一个创新的框架&#xff0c;它正在彻底改变我们开发由语言模型驱动的应用程序的方式。通过结合先进的原则&#xff0c;LangChain正在重新定义通过传统API可以实现的极限。 在上一篇博…

一文读懂!一年耗能堪比2个三峡电站的大数据中心,背后竟隐藏着这些秘密......

全国大数据中心1年的能耗规模相当于2个三峡电站一整年的发电量&#xff0c;这是为什么&#xff1f; 大数据中心每耗费1度电&#xff0c;只有一半用在了“计算”上面&#xff0c;其他的都应用在散热、照明等方面到底是怎么回事&#xff1f; 为什么说在算力上每投入1元&#xff0…

【二】数据库系统

数据库系统的分层抽象DBMS 数据的三个层次从 数据 到 数据的结构----模式数据库系统的三级模式&#xff08;三级视图&#xff09;数据库系统的两层映像数据库系统的两个独立性数据库系统的标准结构 数据模型从 模式 到 模式的结构----数据模型三大经典数据模型 数据库的演变与发…

【系统软件03】centos7安装和使用node-v18.16.0(centos7升级glibc 2.28)

【系统软件03】centos7安装和使用node-v18.16.0&#xff08;centos7升级glibc 2.28&#xff09; 前言&#xff1a;本文是解决node 18.16.0的依赖问题&#xff0c;具体的node安装流程&#xff0c;可以参考我的另外一篇文章。一、下载node v18.16.0二、下载glibc2.28&#xff08;…

uniapp使用阿里矢量库

然后解压复制全部到你的项目文件 最后只要这几个 然后引入 最后在你需要的页面使用

JavaWeb中Json传参的条件

JavaWeb中我们常用json进行参数传递 对应的注释为RequestBody 但是json传参是有条件的 最主要是你指定的实体类和对应的json参数能否匹配 1.属性和对应的json参数名称对应 2.对应实体类实现了Serializable接口&#xff0c;可以进行序列化和反序列化&#xff0c;这个才是实体类转…

Ajax同源策略及跨域问题

Ajax同源策略及跨域问题 同源策略ajax跨域问题什么是跨域&#xff1f;为什么不允许跨域&#xff1f;跨域解决方案1、CORS2、express自带的中间件cors3、JSONP原生JSONPjQuery发送JSONP 4、使用vscode的Live Server插件 同源策略 同源策略&#xff08;Same-Origin Policy&#…

电脑合上盖子无线网络不会断开

控制面板\硬件和声音\电源选项\系统设置 最终选择不会采取任何操作 选择不会采取任何操作

前端性能优化之性能优化的指标和工具(chrome devtools、lighthouse、webpagetest)

文章目录 引言一、为什么要进行web性能优化二、RAIL测量模型1. 什么是RAIL2. 性能测量工具 三、性能测量工具的使用和性能指标以及优化目标1. Chrome DevTools1. 打开调试工具方式和配置2. network下的几个性能指标1. requests 请求总数2. transferred实际从服务器下载的数据量…

【数据结构与算法】十大经典排序算法-希尔排序

&#x1f31f;个人博客&#xff1a;www.hellocode.top &#x1f3f0;Java知识导航&#xff1a;Java-Navigate &#x1f525;CSDN&#xff1a;HelloCode. &#x1f31e;知乎&#xff1a;HelloCode &#x1f334;掘金&#xff1a;HelloCode ⚡如有问题&#xff0c;欢迎指正&#…

手撕数据结构之栈+例题

目录 一、栈的概念及结构 二、栈的头文件及基本框架 三、接口实现 1、对栈的初始化 2、栈的销毁 3、入栈操作 4、出栈操作 5、判断栈是否为空 6、返回栈顶元素 7、遍历栈 四、有效的括号 - 力扣&#xff08;LeetCode&#xff09; 题目描述&#xff1a; 思路&#xff…

静态网页和动态网页区别

1&#xff0c;静态网页和动态网页有何区别 1) 更新和维护 静态网页内容一经发布到网站服务器上&#xff0c;无论是否有用户访问&#xff0c;这些网页内容都是保存在网站服务器上的。如果要修改网页的内容&#xff0c;就必须修改其源文件&#xff0c;然后重新上传到服务器上。…

k8s-----集群调度

目录 一&#xff1a;调度约束 二&#xff1a;Pod 启动创建过程 三&#xff1a;k8s调度过程 1、Predicate 有一系列的常见的算法 2、常见优先级选项 3、指定调度节点 &#xff08;1&#xff09;nodeName指定 &#xff08;2&#xff09;nodeSelector指定 四&#xff1a;亲和…

C++——继承

文章目录 &#x1f99c;1. 什么是继承&#x1f40a;1.1 概念&#x1f40a;1.2 格式&#x1f40a;1.3 继承方式 & 访问限定符 &#x1f426;2. 派生类和基类的赋值问题&#x1f9a9;3. 派生类和基类同名成员问题&#x1f413;4.派生类默认成员函数&#x1f409;4.1 构造函数…

React源码解析18(1)------ React.createElement 和 jsx

1.React.createElement 我们知道在React17版本之前&#xff0c;我们在项目中是一定需要引入react的。 import React from “react” 即便我们有时候没有使用到React&#xff0c;也需要引入。原因是什么呢&#xff1f; 在React项目中&#xff0c;如果我们使用了模板语法JSX&am…

单调递增的数字——力扣738

文章目录 题目描述解法题目描述 解法 #include<iostream> #include<string>using namespace std;int monotoneIncreasingDigits

中小企业项目管理软件推荐:选择适合的工具提升项目效率!

中小企业项目管理软件有哪些&#xff1f;Zoho Projects是一款好用无广告的项目管理软件。当个小创业者是真的不容易&#xff0c;不仅要管理团队&#xff0c;还要管理团队项目。很多团队之前用了好多项目管理的软件&#xff0c;但是都不太满意。但是如果你经常参加创业者聚会上&…