基于C语言实现扫雷小游戏

扫雷游戏

  • 1. 扫雷游戏分析和设计
    • 1.1 扫雷游戏的功能说明
    • 1.2 游戏的分析和设计
    • 1.2.1 数据结构的分析
  • 2. 扫雷游戏的代码实现
  • 3. 扫雷游戏的扩展


1. 扫雷游戏分析和设计

1.1 扫雷游戏的功能说明

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

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

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

  • 默认随机布置10个雷

  • 可以排查雷

  • 如果位置不是雷,就显示周围有几个雷

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

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

游戏的界面:

在这里插入图片描述

1.2 游戏的分析和设计

1.2.1 数据结构的分析

扫雷的过程中,布置的雷和排查出的雷的信息都需要存储,所以我们需要⼀定的数据结构来存储这些信息。

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

空棋盘

在这里插入图片描述
如果这个位置布置雷,我们就存放1,没有布置雷就存放0.

布置雷的棋盘

在这里插入图片描述
假设我们排查(2,5)这个坐标时,我们访问周围的一圈8个黄色位置,统计周围雷的个数是1

假设我们排查(8,6)这个坐标时,我们访问周围的一圈8个黄色位置,统计周围雷的个数时,最下面的三个坐标就会越界,为了防止越界,我们在设计的时候,给数组扩大一圈,雷还是布置在中间的9 * 9的坐 标上,周围一圈不去布置雷就行,这样就解决了越界的问题。所以我们将存放数据的数组创建成11 * 11 是比较合适。

排雷的假设

在这里插入图片描述

周围加上一圈的棋盘

在这里插入图片描述
再继续分析,我们在棋盘上布置了雷,棋盘上雷的信息(1)和非雷的信息(0),假设我们排查了某⼀个位置后,这个坐标处不是雷,这个坐标的周围有1个雷,那我们需要将排查出的雷的数量信息记录存储,并打印出来,作为排雷的重要参考信息的。那这个雷的个数信息存放在哪里呢?

如果存放在布置雷的数组中,这样雷的信息和雷的个数信息就可能或产生混淆和打印上的困难。
这里我们肯定有办法解决,比如:雷和非雷的信息不要使用数字,使用某些字符就行,这样就避免冲突了,但是这样做棋盘上有雷和非雷的信息,还有排查出的雷的个数信息,就比较混杂,不够方便。

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

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

mine数组布置雷后的状态

在这里插入图片描述

show输出初始化的状态

在这里插入图片描述
对应的数组应该是:

char mine[11][11] = {0}; //⽤来存放布置好的雷的信息
char show[11][11] = {0}; //⽤来存放排查出的雷的个数信息

2. 扫雷游戏的代码实现

text.h


#include <stdio.h>
#include <stdlib.h>
#include <Windows.h>
#include <time.h>

#define row 9
#define line 9
#define ROW 9
#define LINE 9


void menu();//菜单函数
void game();//主游戏函数
void initialization(char (*board)[line],int a,int b, char element);//初始化函数
void SHOW(char(*board)[line], int a, int b);//打印元素
void LAY(char(*board)[line], int a, int b);//放置炸弹
int INSPECT(char(*board)[line], char(*board1)[line] ,int a, int b);//检查炸弹
int win(char(*board)[line], int a, int b);//获胜条件

text.c

#include "text.h"

void menu()
{
	printf("******************************************************\n");
	printf("******************************************************\n");
	printf("**********1. 开始游戏*********0. 退出游戏*************\n");
	printf("******************************************************\n");
	printf("******************************************************\n");
}

void initialization(char (*board)[line], int a, int b, char element)
{
	int i, j;
	for (i = 0; i < a; i++)
	{
		for(j = 0 ; j < b ; j++ )
		{
			board[i][j] = element;
		}
	}
}

void SHOW(char (*board)[line], int a, int b)
{
	int i, j;
	for (i = 0; i < a; i++)
	{
		if (i == 0)
		{
			for (j = 0; j <= b; j++)printf("%3d", j);
			printf("\n");
		}
		printf("%3d", i + 1);
		for (j = 0; j < b; j++)
		{
			printf("%3c", board[i][j]);
		}
		printf("\n");
	}
	printf("\n");
}

void LAY(char(*board)[line], int a, int b)
{
	int c = 0,d = 0,count = row;
	while (count)
	{
		c = rand() % row + 1;
		d = rand() % line + 1;
		if (board[c][d] == '0')
		{
			board[c][d] = '1';
			count--;
		}
	}
}

int INSPECT(char(*board)[line], char(*board1)[LINE], int a, int b)
{
	int c = 0, d = 0,e = 0,f = 0,count = 0;
	if (a + 1 >= ROW) c = a;
	else c = a + 1;
	if (b + 1 >= LINE) d = b;
	else d = b + 1;
	if (a - 1 < 0) e = a;
	else e = a - 1;
	if (b - 1 < 0) f = b;
	else f = b - 1;
	if (board[a][b] == '1')
	{
		printf("you loss \n");
		return 0;
	}
	else
	{
		for (int i = e; i <= c; i++)
		{
			for (int j = f; j <= d ; j++)
			{
				if (board[i][j] == '1')
				{
					count++;
				}
				else
				{
					board1[i][j] = '0';
				}
			}
		}
		printf("周围一共有%d的雷\n", count);
		SHOW(board1, row, line);
	}
}

int win(char(*board)[line], int a, int b)
{
	int count = 0;
	for (int i = 0; i < a; i++)
	{
		for (int j = 0; j < b; j++)
		{
			if (board[i][j] == '*')count++;
		}
	}
	if (count == line)
	{
		printf("you win\n");
		return 0;
	}
	else return 1;
}
void game()
{
	char chessboard[row][line], chessboardshow[ROW][LINE];
	int x = 0, y = 0,count = 1;
	printf("---------------扫雷游戏开始-----------------------\n");
	initialization(chessboard,row,line, '0');
	initialization(chessboardshow,ROW,LINE, '*');
	LAY(chessboard, row, line);
	SHOW(chessboardshow, row, line);
	while(count)
	{
		printf("输入你需要排查的位置: \n" );
		scanf_s("%d%d", &x, &y, 2);
		if (x <= 0 && x >= row)
		{
			printf("error\n");continue;
		}
		if (y <= 0 && y >= line)
		{
			printf("error\n");continue;
		}
		count = INSPECT(chessboard,chessboardshow, x, y);
		count = win(chessboardshow, ROW, LINE);
	}
}

main.c

#include "text.h"

int main()
{
	int a;
	srand((unsigned int)time(NULL));
	do
	{
		menu();
		scanf_s("%d", &a, 1);
		switch(a)
		{
		case 1:game(); break;
		case 0:exit(0); break;
		default:continue;
		}
	} while (1);
	system("pause");
	return 0;
}

3. 扫雷游戏的扩展

  • 是否可以选择游戏难度 可以通过修改宏定义,来实现棋盘难度的选择

  • 简单 9*9 棋盘,10个雷

  • 中等 16*16棋盘,40个雷

  • 困难 30*16棋盘,99个雷

  • 是否可以标记雷 ——待完善

  • 是否可以加上排雷的时间显示 ——待完善

在线扫雷游戏


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

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

相关文章

【考研数学】概率论与数理统计 —— 第七章 | 参数估计(2,参数估计量的评价、正态总体的区间估计)

文章目录 一、参数估计量的评价标准1.1 无偏性1.2 有效性1.3 一致性 二、一个正态总体参数的双侧区间估计2.1 对参数 μ \mu μ 的双侧区间估计 三、一个正态总体的单侧置信区间四、两个正态总体的双侧置信区间写在最后 一、参数估计量的评价标准 1.1 无偏性 设 X X X 为总…

技能证里的天花板—阿里云云计算架构师ACE认证!

在当今的社会中&#xff0c;想要获得一份好工作、得到丰厚的报酬&#xff0c;唯一的方法就是证明自己优秀&#xff0c;能给公司创造价值&#xff0c;是大多数公司想要看到的。 那么在面试过程中&#xff0c;怎么样才能让面试官一眼就记住呢&#xff1f;那一定是有一份足够优秀…

JVM虚拟机:JVM的垃圾回收清除算法(GC)有哪些

垃圾回收清除算法 引用计数法 标记清除 拷贝算法 标记压缩 引用计数法 有一个引用指向对象,那么引用计数就加1,少一个引用指向,那么引用计数就减1,这种方法了解一下就好,JVM机会不会使用这种方法,因为它在每次对象赋值的时候都要维护引用计数器,且计数器本身也有一定的…

JAVA虚拟机-第2章 Java自动内存管理-异常实践

Java堆溢出 堆的参数设置&#xff1a;将堆的最小值-Xms参数与最大值-Xmx参数设置 public class HeapOOM {static class OOMObject {}public static void main(String[] args) {List<OOMObject> list new ArrayList<OOMObject>();while (true) {list.add(new OO…

idea 配置checkstyle全过程

checkstyle是提高代码质量,检查代码规范的很好用的一款工具&#xff0c;本文简单介绍一下集成的步骤&#xff0c;并提供一份完整的checkstyle的代码规范格式文件&#xff0c;以及常见的格式问题的解决方法。 一&#xff0c;安装 打开idea的文件选项&#xff0c;选择设置&…

Unity3D实现页面的滑动切换功能

效果展示 Unity3D实现页面的滑动切换 效果 文章目录 前言一、先上代码二、创建UI1.创建Scroll View如下图&#xff0c;并挂载该脚本&#xff1a;2.Content下创建几个Itme 总结 前言 好记性不如烂笔头&#xff01; 一、先上代码 /*******************************************…

前端性能分析工具

前段时间在工作中,需要判断模块bundle size缩减对页面的哪些性能产生了影响, 因此需要了解前端的性能指标如何定义的,以及前端有哪些性能分析工具, 于是顺便整理了一篇笔记, 以供前端小白对性能这块知识点做一个入门级的了解. 页面渲染 在了解性能指标和分析工具之前,有必要先…

怎样去除视频中的杂音,保留人声部分?

怎样去除视频中的杂音&#xff0c;保留人声部分&#xff1f;这个简单嘛&#xff01;两种办法可以搞定&#xff1a;一是进行音频降噪&#xff0c;把无用的杂音消除掉&#xff1b;二是提取人声&#xff0c;将要保留的人声片段提取出来。 这就将两种实用的办公都分享出来&#xf…

datagrip出现 java.net.ConnectException: Connection refused: connect.

出现这样的情况要看一下hadoop有没有启动 start-all.sh nohup /export/server/apache-hive-3.1.2-bin/bin/hive --service hiveserver2 & scp -r /export/server/apache-hive-3.1.2-bin/ node3:/export/server/ /export/server/apache-hive-3.1.2-bin/bin/hive show databa…

Apache POI

文章目录 一、Apache POI介绍二、应用场景三、使用步骤1.导入maven坐标2.写入代码讲解3.读取代码讲解 一、Apache POI介绍 Apache POI 是一个处理Miscrosoft Office各种文件格式的开源项目。简单来说就是&#xff0c;我们可以使用 POI 在 Java 程序中对Miscrosoft Office各种文…

pytorch 笔记:GRU

1 介绍 对于输入序列中的每个元素&#xff0c;每一层都计算以下函数&#xff1a; ht​ 是t时刻 的隐藏状态xt​ 是t时刻 的输入ht−1​ 是 t-1时刻 同层的隐藏状态或 0时刻 的初始隐藏状态rt​,zt​,nt​ 分别是重置门、更新门和新门。σ 是 sigmoid 函数∗ 是 Hadamard 乘积。…

coalesce函数(SQL )

用途&#xff1a; 将控制替换成其他值&#xff1b;返回第一个非空值 表达式 COALESCE是一个函数&#xff0c; (expression_1, expression_2, …,expression_n)依次参考各参数表达式&#xff0c;遇到非null值即停止并返回该值。如果所有的表达式都是空值&#xff0c;最终将返…

HarmonyOS鸿蒙原生应用开发设计- 元服务(原子化服务)图标

HarmonyOS设计文档中&#xff0c;为大家提供了独特的元服务图标&#xff0c;开发者可以根据需要直接引用。 开发者直接使用官方提供的元服务图标内容&#xff0c;既可以符合HarmonyOS原生应用的开发上架运营规范&#xff0c;又可以防止使用别人的元服务图标侵权意外情况等&…

关于网络编程的3个问题

一、TCP 和 UDP 可以同时绑定相同的端口吗&#xff1f; 答案&#xff1a;可以的 在数据链路层中&#xff0c;通过 MAC 地址来寻找局域网中的主机。在网络层中&#xff0c;通过 IP 地址来寻找网络中互连的主机或路由器。在传输层中&#xff0c;需要通过端口进行寻址&#xff0…

SpringCloud(五) Eureka与Nacos的区别

SpringCloud(二) Eureka注册中心的使用-CSDN博客 SpringCloud(四) Nacos注册中心-CSDN博客 在这两篇博文中我们详细讲解了Eureka和Nacos分别作为微服务的注册中心的使用方法和注意事项,但是两者之间也有一些区别. 一, Nacos实例分类 Nacos实例分为两种类型: 临时实例:如果实例…

[common c/c++] ring buffer/circular buffer 环形队列/环形缓冲区

前言&#xff1a; ring buffer / circular buffer 又名环形队列 / 环形缓冲区&#xff0c;其通过开辟固定尺寸的内存来实现反复复用同一块内存的目的。由于预先开辟了固定尺寸的内容&#xff0c;所以当数据满的时候&#xff0c;可以有两种处理方式&#xff0c;具体使用哪一种按…

思路视野杂志思路视野杂志社思路视野编辑部2023年第24期目录

公共文化 公共图书馆文旅融合实践与模式思考 白雪1-3 公共图书馆管理与服务创新路径分析 陈静4-6 提升办公室文书档案管理工作的实践探讨 黄强7-9 《思路视野》投稿邮箱&#xff1a;cn7kantougao163.com(注明投稿“《思路视野》”) 崔编辑Q Q &#xff1a;296078736 微信号&am…

ajax-axios发送 get请求 或者 发送post请求带有请求体参数

/* axios v0.21.1 | (c) 2020 by Matt Zabriskie */ !function(e,t){"object"typeof exports&&"object"typeof module?module.exportst():"function"typeof define&&define.amd?define([],t):"object"typeof export…

瑞明达:聚“追梦”之力,共圆“经济梦”

矢志不渝&#xff0c;笃行不怠&#xff0c;争当“一心一意同国行”的无悔“追梦人”。过往几年&#xff0c;国际形势风高浪急&#xff0c;国内环境复杂多变&#xff0c;在后疫情时代、经济恢复压力等多种超预期的因素冲击下&#xff0c;瑞明达团队全面贯彻落实国家发展政策&…

为什么 SIEM 是抵御网络威胁的最佳防御手段

随着 IT 服务和基础设施趋向于混合模式&#xff0c;以及最近数据的激增&#xff0c;组织必须拥有一个集中式安全解决方案来跟踪用户的行为和关键安全事件。 威胁行为者越来越善于检测和利用组织网络中的漏洞&#xff0c;网络攻击也在不断发展。虽然管理员可以对已经发生的攻击…