扫雷的实现
前言
C语言实现扫雷游戏
# 一、游戏的思路
先理清游戏大概需要实现的功能,菜单功能的实现、棋盘初始化、打印棋盘、布置雷等。运用两个数组,一个放入布置雷的信息,另一个放入排查雷的信息。选一个坐标扫雷,坐标有雷则游戏结束,没有就计算选中坐标的周围8个格子中雷的总数放入选中的坐标中,若选中的坐标周围8个格子中都没有雷则自动展开。考虑到棋盘边框的情况,实际数组要比打印出的棋盘多两行两列。下面是宏定义和函数声明:
ROW、COL为打印行、列,ROWS、COLS为实际的数组行列
EASY_COUNT为雷的个数,可根据需要调整行列和雷的个数
#define ROW 9
#define COL 9
#define ROWS ROW+2
#define COLS COL+2
#define EASY_COUNT 10
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<Windows.h>
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 board[ROWS][COLS], int row, int col);
void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);
void ExcludeMine(char mine[ROWS][COLS], char show[ROWS][COLS], int x, int y);
二、游戏测试
游戏实现的大致思路体现和菜单的实现,代码如下:
#define _CRT_SECURE_NO_WARNINGS 1
#include"game.h"
void menu()
{
printf("##############################\n");
printf("###### 1. play 0.exit ######\n");
printf("##############################\n");
}
//布置雷 - 字符组存储 - 雷用1表示,非雷用0表示 - 最外层一圈放0
//排查雷 - 为避免歧义,再用一个字符组存储排查出来的雷的信息 - 未排除的用#表示
//最外层加一圈字符,只在中间设置雷,并打印展示棋盘中间位置,因此实际存放数组要比打印的棋盘多两行两列
void game()
{
//雷的信息存储
//1.布置好的雷的信息
char mine[ROWS][COLS] = {
0 };
//2.排查出的雷的信息
char show[ROWS][COLS] = {
0 };
//初始化
InitBoard(mine, ROWS, COLS, '0');
InitBoard(show, ROWS, COLS, '#');