IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 我三岁兄弟看了都会写的C语言扫雷教程 -> 正文阅读

[C++知识库]我三岁兄弟看了都会写的C语言扫雷教程

提供给玩家选择玩游戏和退出的函数。当玩家选择1,游戏开始;玩家选择0,游戏退出。我们把游戏开始的函数都放在play()函数中。

void meau()
{
	printf("**************************************\n");
	printf("**************************************\n");
	printf("**************************************\n");
	printf("***********  1. play    **************\n");
	printf("***********  0. exit    **************\n");
	printf("**************************************\n");
	printf("**************************************\n");
	printf("**************************************\n");

}
void test()
{
	srand((unsigned int)time(NULL));
	int input = 0;
	do
	{
		meau();
		printf("请选择开始>\n");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			printf("开始游戏>\n");
			play();
			break;
		case 0:
			printf("退出游戏>\n");
			break;
		default:
			printf("请输入正确的选择>\n");
			break;
		}

	} while (input);

}

?扫雷的界面是一个9*9的方格,但是为了我们方便统计方格周边雷的数量,所以我们把数组扩大为11*11。所以我们用两个数组来进行处理。一个数组用来打印给玩家看。另一个数组用来游戏内部的处理。并进行初始化。

	//初始化数组
	initboard(mine, ROWS,COLS,'0');
	initboard(show, ROWS, COLS, '*');
void initboard(char board[ROWS][COLS], int row, int col, char set)
{
	int i = 0;
	int j = 0;
	for ( i = 0;i <row;i++)
	{
		for (j = 0;j <col;j++)
		{
			board[i][j] = set;
		}
	}
}

为了方便打印出扫雷的界面,我们定义一个函数。并在初始化结束后打印出扫雷的界面。

void disboard(char board[ROWS][COLS], int row, int col)
{
	for (int i = 0;i <= col;i++)
	{
		printf("%d ", i);
	}
	printf("\n");
	for (int i = 1;i <= row;i++)
	{
		printf("%d ", i);
		for (int j=1;j<=col;j++)
		{
			printf("%c ", board[i][j]);
		}
		printf("\n");
	}
}

?下一步开始布置雷。

void setmine(char board[ROWS][COLS], int row, int col)
{
	int count = easycode;
	while (count)
	{
		int x = rand() % 9 + 1;
		int y = rand() % 9 + 1;
		if (board[x][y] == '0')
		{
			board[x][y] = '1';
			count--;
		}
		
	}
}

玩家选择了一个位置后,如果不是雷会统计周围雷的数量;如果周围也没有雷就会继续展开。

//展开
void open(char mine[ROWS][COLS], char show[ROWS][COLS], int x, int y)
{
	if (mine[x - 1][y - 1] == '0')
	{
		show[x - 1][y - 1] = count(mine, x - 1, y - 1) + '0';
	}
	if (mine[x - 1][y] == '0')
	{
		show[x - 1][y] = count(mine, x - 1, y) + '0';
	}
	if (mine[x - 1][y + 1] == '0')
	{
		show[x - 1][y + 1] = count(mine, x - 1, y + 1) + '0';
	}
	if (mine[x][y - 1] == '0')
	{
		show[x][y - 1] = count(mine, x, y - 1) + '0';
	}
	if (mine[x][y + 1] == '0')
	{
		show[x][y + 1] = count(mine, x, y + 1) + '0';
	}
	if (mine[x + 1][y - 1] == '0')
	{
		show[x + 1][y - 1] = count(mine, x + 1, y - 1) + '0';
	}
	if (mine[x + 1][y] == '0')
	{
		show[x + 1][y] = count(mine, x + 1, y) + '0';
	}
	if (mine[x + 1][y + 1] == '0')
	{
		show[x + 1][y + 1] = count(mine, x + 1, y + 1) + '0';
	}

}

//统计周围雷的数量
int count(char mine[ROWS][COLS],int x, int y)
{
	return mine[x - 1][y] +
		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] +
		

雷布置结束就是处理游戏进行中的逻辑。扫雷游戏第一次是不能够碰见雷的。如果玩家运气不好第一次就选择了雷,我们定义一个safe函数防止玩家第一次选择就被炸死。

//防止第一次被炸死
void safe(char mine[ROWS][COLS],char show[ROWS][COLS],int row,int col)
{
	int x = 0;
	int y = 0;
	int cont = 0;
	while (1)
	{
		printf("请输入排雷的坐标>");
		scanf("%d %d", &x, &y);
		if (x >= 1 && x <= 9 && y >= 1 && y <= 9)
		{
			if (mine[x][y] == '1')
			{
				mine[x][y] = '0';
				cont = count(mine, x, y);
				show[x][y] = cont + '0';//统计雷
				open(mine, show, x, y);
				disboard(show, ROW, COL);
				//sign(show[ROWS][COLS]);
				//安排一个雷
				while (1)
				{
					int a = rand() % 9 + 1;
					int b = rand() % 9 + 1;
					if (mine[a][b] == '0')
					{
						show[a][b] = '1';
						break;
					}
				}
			}
			else
			{
				cont = count(mine, x, y);
				show[x][y] = cont + '0';
				open(mine, show, x, y);
				disboard(show, ROW, COL);
			}
			break;
		}
		else
		{
			printf("请输入正确的坐标\n");
		}
	}
}

最后是扫雷游戏的主要函数

void findmine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{
	int x = 0;
	int y = 0;
	int win = 0;
	while (win < row * col - easycode - 1)
	{
		printf("请选择雷的坐标>\n");
		scanf("%d %d", &x, &y);
		if (x >= 1 && x <= 9 && y >= 1 && y <= 9)
		{
			if (mine[x][y] == '1')
			{
				printf("很遗憾你被炸死了!\n");
				disboard(mine, ROW, COL);
				break;
			}
			//统计周围雷的数量
			else
			{
				int n = count(mine, x, y);
				show[x][y] = '0' + n;
				open(mine, show, x, y);
				disboard(show, ROW, COL);
				win++;
			}
		}
		else
		{
			printf("请输入正确的坐标\n");
		}
	}
	if (win == row * col - easycode - 1)
	{
		printf("恭喜你排雷成功!\n");
		disboard(mine, ROW, COL);

	}

}

play()函数的逻辑

void play()
{
	char mine[ROWS][COLS] = { 0 };
	char show[ROWS][COLS] = { 0 };
	//初始化数组
	initboard(mine, ROWS,COLS,'0');
	initboard(show, ROWS, COLS, '*');
	//打印棋盘
	disboard(show, ROW, COL);
	//布置雷
	setmine(mine, ROW, COL);
	safe(mine, show, ROW, COL);
	findmine(mine, show, ROW, COL);
}

头文件

#include<stdio.h>
#include<string.h>
#include<time.h>
#define ROW 9
#define COL 9
#define ROWS ROW+2	
#define COLS COL+2
#define easycode 10
void initboard(char board[ROWS][COLS], int row, int col,char set);
void disboard(char board[ROWS][COLS],int row, int col);
void setmine(char board[ROWS][COLS], int row, int col);
void findmine(char MINE[ROWS][COLS], char SHOW[ROWS][COLS], int row, int col);
void safe(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);

游戏的运行截图

?

?

?

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-11-12 19:24:25  更:2021-11-12 19:24:51 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 10:06:35-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码