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语言系列 扫雷小游戏


前言

《扫雷》是一款大众类的益智小游戏,于1992年发行。游戏目标是在最短的时间内根据点击格子出现的数字找出所有非雷格子,同时避免踩雷,踩到一个雷即全盘皆输。

一、初始化游戏菜单并导入头文件

1.

#include"mines.h"

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

int main(void)
{
	int input = 0;
	do
	{
		neum();
		printf("请输入:>");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
		{
			system("cls");
			game();
			break;
		}
		case 0:
		{
			printf("退出游戏\n");
			break;
		}
		default:
			printf("选择错误请重选\n");
			break;
		}
	} while (input);
	return 0;
}

2.

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

#define COUNT 10
#define ROW 10
#define COL 10

#define ROWS ROW+2
#define COLS COL+2




void lnitbrod(char broad[ROWS][COLS], int row, int col); //初始化棋盘

void lnitbrod2(char broad[ROWS][COLS], int row, int col); //初始化棋盘2

void Layoutbroad(char mine[ROWS][COLS], int row, int col, int count); //随机布置雷数

void showbroad(char broad[ROWS][COLS], int row, int col); //展示棋盘

void playgame(char broad[ROWS][COLS], char show[ROWS][COLS]); //主游戏函数

二、设计游戏函数

代码如下:

void game()
{
	srand((unsigned int)time(NULL));//设置随机时间值
	char broad[ROWS][COLS];
	char show[ROWS][COLS];
	lnitbrod(broad, ROWS, COLS);//初始化真棋盘
	lnitbrod2(show, ROW, COL);//初始化展示棋盘
	Layoutbroad(broad, ROW, COL, COUNT);//随机布置雷数 现是:10
	showbroad(show, ROW, COL);//展示棋盘
	playgame(broad, show);//判断游戏输赢机制
}

三、进入游戏函数并开始执行

代码如下:

#include"mines.h"

void lnitbrod(char broad[ROWS][COLS],int row,int col) //初始化
{
	for (int i = 0; i < row;i++)
	{
		for (int j = 0; j < col; j++)
		{
			broad[i][j] = '0';
		}
	}
}

void lnitbrod2(char broad[ROWS][COLS], int row, int col)//初始化
{
	for (int i = 1; i <= row; i++)
	{
		for (int j = 1; j <= col; j++)
		{
			broad[i][j] = '*';
		}
	}
}

void Layoutbroad(char mine[ROWS][COLS], int row, int col,int count) //随机布置雷数
{
	while (count)
	{
		int x = rand() % row + 1;
		int y = rand() % col + 1;
		mine[x][y] = '1';
		count--;
	}
}

void showbroad(char broad[ROWS][COLS], int row, int col)//展示棋盘
{
	printf("    ");
	for (int i = 1; i <= row; i++)
	{
		printf("%d ", i);
	}
	printf("\n");
	printf("   ");
	for (int i = 0; i < row; i++)
	{
		printf("--");
	}
	printf("\n");

	for (int i = 1; i <=row; i++)
	{
		printf("%2d|", i);
		for (int j = 1; j <= col; j++)
		{
			printf(" %c", broad[i][j]);
		}
		printf("\n");
	}
}

int getmine(char mine[ROWS][COLS], int i, int j)//获取真棋盘周围8个格子的雷数
{
	return mine[i + 1][j] + mine[i - 1][j] + mine[i][j - 1] +
		mine[i][j + 1] + mine[i + 1][j + 1] + mine[i - 1][j - 1] +
		mine[i - 1][j + 1] + mine[i + 1][j - 1] - 8 * '0';
}

void Expand(char mine[ROWS][COLS], char show[ROWS][COLS], int x, int y, int* win)//递归展开函数
{
	for (int i = -1; i < 2; i++)
	{
		for (int j = -1; j < 2; j++)
		{
			if (i != 0 || j != 0)
			{
				if (x + i >= 1 && x + i <= ROW && y + j >= 1 && y + j <= COL && mine[x + i][y + j] != '1')
				{
					if (show[x + i][y + j] == '*' && mine[x + i][y + j] == '0')
					{
						int count = getmine(mine, x + i, y + j);
						if (count != 0)
						{
							show[x + i][y + j] = count + '0';
							(*win)++;
						}
						else
						{
							show[x + i][y + j] = ' ';
							Expand(mine, show, x + i, y + j, win);
							(*win)++;
						}
					}
				}
			}
		}
	}
}

void gameover(char broad[ROWS][COLS], int row, int col)//如果游戏结束 则展示真棋盘
{
	for (int i = 1; i <= row; i++)
	{
		for (int j = 1; j <= col; j++)
		{
			if (broad[i][j] == '1')
			{
				printf("* ");
			}
			else
			{
				printf("O ");
			}
		}
		printf("\n");
	}
}

void playgame(char broad[ROWS][COLS],char show[ROWS][COLS])//游戏机制主体函数
{
	int x = 0;
	int y = 0;
	int count = 0;
	int win = 0;
	while (win<ROW*COL-count)
	{
		printf("请输入坐标(行数,列数):>");
		scanf("%d %d", &x, &y);
		if (x >= 1 && x <= ROW && y >= 1 && y <= COL)
		{
			if (broad[x][y] == '1')
			{
				printf("顺干爆炸,game over\n");
				gameover(broad, ROW, COL);
				return;
			}
			else
			{
				count = getmine(broad, x, y);
				if (count != 0)
				{
					show[x][y] = count + '0';
				}
				else
				{
					show[x][y] = ' ';
					system("cls");
					Expand(broad, show, x, y, &win);
				}
				showbroad(show, ROW, COL);
			}
		}
		else
		{
			printf("输入非法请重试\n");
		}
	}
	if (win - ROW * COL - count == 0)
	{
		printf("恭喜排雷成功\n");
		return;
	}
}

总结

运行结果如下
开始菜单:

展示:

输入 5 5
在这里插入图片描述
游戏结束:
在这里插入图片描述

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2021-08-01 14:48:33  更:2021-08-01 14:48:54 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年4日历 -2024/4/29 1:09:12-

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