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 --- 9
		int 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://www.mfbz.cn/a/611646.html

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

相关文章

画出入学管理系统的顶层图和1层图

&#xff08;学校作业&#xff09; 题目如下&#xff1a; 某培训机构入学管理系统有报名、交费和就读等多项功能&#xff0c;下面是对其各项功能的说明&#xff1a; 1、报名&#xff1a;由报名处负责&#xff0c;需要在学员登记表上进行报名登记&#xff0c;需要查询课…

Kettle连接Mysql数据库时报错——Driver class ‘org.gjt.mm.mysql.Driver‘ could not be found

一、问题描述 当我们使用ETL工具Kettle需要连接Mysql数据库进行数据清洗操作,在配置好Mysql的连接串内容后,点击【测试】按钮时报错【错误连接数据库 [MysqlTestConnection] : org.pentaho.di.core.exception.KettleDatabaseException: Error occurred while trying to conne…

记一次DNS故障导致用户无法充值的问题(下)

上一篇说到DNS故障导致无法充值&#xff0c;后来我们通过拨测发现业务域名的解析目标地址被解析到了【127.0.0.1】IP。 1、联系阿里云厂商&#xff0c;通过沟通&#xff0c;阿里云反馈我们的域名被XX省通管单位封禁了&#xff0c;导致解析到了不正确的地址。 2、为了解决用户问…

idea运行SpringBoot项目爆红提示出现:Java HotSpot(TM) 64-Bit Server VM warning...让我来看看~

在运行SpringBoot项目的时候&#xff0c;发现总有这个警告提示出现&#xff0c;有点强迫症真的每次运行项目都很难受啊&#xff01;那么今天便来解决这个问题&#xff01; 先来看一下提示内容&#xff1a;Java HotSpot(TM) 64-Bit Server VM warning: Options -Xverify:none an…

多目标跟踪入门介绍

多目标跟踪算法 我们也可以称之为 Multi-Target-Tracking &#xff08;MTT&#xff09;。 那么多目标跟踪是什么&#xff1f; 不难看出&#xff0c;跟踪算法同时会为每个目标分配一个特定的 id 。 由此得出了目标跟踪与目标检测的区别&#xff08;似乎都是用方框来框出目标捏…

树与二叉树之间的转换

树转化成二叉树&#xff1a;兄弟相连留长子 1.加线&#xff1a;在兄弟之间加一条线 2.抹线&#xff1a;对每个结点&#xff0c;除了其左孩子外&#xff0c;去除其与其余孩子之间的关系 3.旋转&#xff1a;以树的根结点为轴心&#xff0c;将整树顺时针转45 二叉树转化成为树…

云衔科技成为卓豪Zoho中国区代理商,开启智能化企业管理新篇章

每一家企业数字化转型&#xff0c;都在寻求通过技术创新实现业务的飞跃。为了更好地服务于中国企业的数字化转型需求&#xff0c;云衔科技荣幸宣布正式成为卓豪Zoho中国区代理商&#xff0c;这一强强联合将为市场带来全新的数字化解决方案与服务体验&#xff0c;共同开启中国企…

Oracle -在线回缩表

conn scott/tiger DROP TABLE EMP1 PURGE; CREATE TABLE EMP1 AS SELECT * FROM EMP; alter table emp1 enable row movement; -- 启动回缩特性 insert into emp1 select * from emp1; / / commit; -- 增加到14000行 -- 分析表的结构 analyze table emp1 comput…

20240510每日后端---聊聊文件预览,doc,image,ppt转PDF预览

一、引入依赖 <dependency><groupId>com.aspose</groupId><artifactId>aspose-words</artifactId><version>15.8</version></dependency><dependency><groupId>com.aspose</groupId><artifactId>crac…

关于JAVA-JSP电子政务网实现参考论文(论文 + 源码)

【免费】关于JAVA-JSP电子政务网.zip资源-CSDN文库https://download.csdn.net/download/JW_559/89292355关于JAVA-JSP电子政务网 摘 要 当前阶段&#xff0c;伴随着社会信息技术的快速发展&#xff0c;使得电子政务能够成为我国政府职能部门进行办公管理的一个重要内容&#x…

代码随想录算法训练营第36期DAY24

DAY24 235二叉搜索树的最近公共祖先 迭代法&#xff1a; /** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; */class Solutio…

ssrf(第二弹)

四&#xff0c;post请求 1.打开环境&#xff0c;提示说发一个HTTP POST请求&#xff0c;ssrf是用php的curl实现的.并且会跟踪302跳转。 2.用dirsearch扫一下常见的端口&#xff0c;看到有三个可以访问的页面 3.构造伪协议&#xff0c;因为要通过172.0.0.1访问&#xff0c;我们…

在centos7中运行向量数据库PostgreSQL连接不上如何排查?

1. 检查 PostgreSQL 服务状态 首先&#xff0c;您需要确认 PostgreSQL 服务是否正在运行。您可以使用以下命令来检查服务状态&#xff1a; sudo systemctl status postgresql如果服务没有运行&#xff0c;您需要启动它&#xff1a; sudo systemctl start postgresql2. 确认 …

锚索测力计在岩土工程中的应用

随着现代工程建设的快速发展&#xff0c;岩土工程安全问题日益受到人们的关注。岩土工程中的锚索结构&#xff0c;作为保证工程稳定和安全的关键部分&#xff0c;其性能监测和评估显得尤为重要。近年来&#xff0c;锚索测力计作为一种先进的监测工具&#xff0c;在岩土工程安全…

粗俗理解多层感知器

一、前言 参考资料和图片均来自以下链接&#xff1a;https://www.youtube.com/watch?vaircAruvnKk&listPLZHQObOWTQDNU6R1_67000Dx_ZCJB-3pihttps://www.youtube.com/watch?vbfmFfD2RIcghttps://www.youtube.com/watch?vKuXjwB4LzSAhttps://www.youtube.com/watch?vIl…

2024数维杯数学建模竞赛A题完整代码和思路论文解析

2024数维杯数学建模完整代码和成品论文已更新&#xff0c;获取↓↓↓↓↓ https://www.yuque.com/u42168770/qv6z0d/bgic2nbxs2h41pvt?singleDoc# 2024数维杯数学建模A题34页论文已完成&#xff0c;论文包括摘要、问题重述、问题分析、模型假设、符号说明、模型的建立和求解&…

linux下使用jexus部署aspnet站点

1.运行环境 Centos 7 安装dos2unix工具 yum install dos2unix 安装jexus curl https://jexus.org/release/x64/install.sh|sudo sh2.网站部署 2.1. 将windows下的网站发布包Msc_qingdao_admin.zip上传到linux中&#xff0c; 然后解压后放入/var/www(没有则创建)目录下 r…

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

ICode国际青少年编程竞赛- Python-4级训练场-绿色能量1 1、 Dev.step(3) Dev.turnLeft() Dev.step(3) Spaceship.step(4) Spaceship.turnRight() Spaceship.step(4) Dev.step(3) while Item[1].y ! Dev.y:wait()2、 Dev.step(4) while Item[0].x ! Dev.x:wait() Dev.turnLe…

AScript纯本地离线文字识别插件

目的 AScript是一款可以模拟鼠标和键盘操作的自动化工具。它可以帮助用户自动完成一些重复的、繁琐的任务&#xff0c;节省大量人工操作的时间。但按键精灵是不包含图色功能&#xff0c;无法识别屏幕上的图像&#xff0c;根据图像的变化自动执行相应的操作。本篇文章主要讲解下…

15 华三华为链路聚合综述

1 链路聚合简介 以太网链路聚合通过将多条以太网物理链路捆绑在一起形成一条以太网逻辑链路&#xff0c;实现增加链路带宽的目的&#xff0c;同时这些捆绑在一起的链路通过相互动态备份&#xff0c;可以有效地提高链路的可靠性。 2 成员端口的状态 聚合组内的成员端口具有以下…
最新文章