实现扫雷游戏的基本思路
使用C语言实现扫雷游戏需要结合二维数组、随机数生成、递归算法等核心概念。游戏的核心逻辑包括初始化雷区、埋雷、计算周围雷数、玩家交互以及胜负判断。
初始化游戏棋盘
定义两个二维数组,一个用于存储实际雷区(mine),另一个用于显示给玩家(show)。雷区通常用字符'1'表示雷,'0'表示安全;显示棋盘用'*'表示未探索区域。
#define ROW 9 #define COL 9 #define MINES 10 char mine[ROW][COL]; // 实际雷区 char show[ROW][COL]; // 显示给玩家的棋盘 // 初始化棋盘 void InitBoard(char board[ROW][COL], char set) { for (int i = 0; i < ROW; i++) { for (int j = 0; j < COL; j++) { board[i][j] = set; } } }随机埋雷
使用rand()函数在雷区随机生成雷的位置,需确保同一位置不重复埋雷。
#include <stdlib.h> #include <time.h> void SetMines(char mine[ROW][COL]) { srand((unsigned int)time(NULL)); int count = MINES; while (count > 0) { int x = rand() % ROW; int y = rand() % COL; if (mine[x][y] == '0') { mine[x][y] = '1'; count--; } } }计算周围雷数
遍历每个非雷格子,统计其周围8个格子中的雷数,并将结果存入显示棋盘。
int GetMineCount(char mine[ROW][COL], int x, int y) { int count = 0; for (int i = -1; i <= 1; i++) { for (int j = -1; j <= 1; j++) { int nx = x + i, ny = y + j; if (nx >= 0 && nx < ROW && ny >= 0 && ny < COL && mine[nx][ny] == '1') { count++; } } } return count; }递归展开空白区域
当玩家点击一个周围无雷的格子时,递归展开所有相邻的空白区域,直到遇到数字边界。
void Expand(char mine[ROW][COL], char show[ROW][COL], int x, int y) { if (x < 0 || x >= ROW || y < 0 || y >= COL || show[x][y] != '*') { return; } int count = GetMineCount(mine, x, y); if (count > 0) { show[x][y] = count + '0'; } else { show[x][y] = ' '; for (int i = -1; i <= 1; i++) { for (int j = -1; j <= 1; j++) { Expand(mine, show, x + i, y + j); } } } }玩家交互与胜负判断
通过循环接收玩家输入坐标,判断是否踩雷或胜利。胜利条件是所有非雷格子均被揭开。
void PlayGame() { int x, y; while (1) { printf("请输入坐标(例如:3 4):"); scanf("%d %d", &x, &y); if (mine[x][y] == '1') { printf("游戏结束!你踩到雷了!\n"); break; } Expand(mine, show, x, y); DisplayBoard(show); if (CheckWin(show)) { printf("恭喜你,扫雷成功!\n"); break; } } } int CheckWin(char show[ROW][COL]) { for (int i = 0; i < ROW; i++) { for (int j = 0; j < COL; j++) { if (show[i][j] == '*' && mine[i][j] == '0') { return 0; } } } return 1; }完整代码结构
- 头文件声明:包含必要的库和函数声明。
- 主函数:调用初始化、埋雷和游戏循环。
- 辅助函数:如打印棋盘、检查胜利条件等。
#include <stdio.h> #include <stdlib.h> #include <time.h> // 函数声明 void InitBoard(char board[ROW][COL], char set); void SetMines(char mine[ROW][COL]); void DisplayBoard(char board[ROW][COL]); void PlayGame(); int main() { InitBoard(mine, '0'); InitBoard(show, '*'); SetMines(mine); DisplayBoard(show); PlayGame(); return 0; }扩展功能建议
- 难度调整:通过宏定义修改
ROW、COL和MINES的值实现不同难度。 - 标记功能:允许玩家标记疑似雷的位置(如用
'F'表示旗子)。 - 计时系统:记录玩家完成游戏的时间。
通过以上步骤,可以实现一个基础的命令行扫雷游戏。如需图形界面,可结合EasyX等库进一步开发。