news 2026/4/15 20:36:38

C语言 扫雷

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C语言 扫雷

实现扫雷游戏的基本思路

使用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; }

完整代码结构

  1. 头文件声明:包含必要的库和函数声明。
  2. 主函数:调用初始化、埋雷和游戏循环。
  3. 辅助函数:如打印棋盘、检查胜利条件等。
#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; }

扩展功能建议

  • 难度调整:通过宏定义修改ROWCOLMINES的值实现不同难度。
  • 标记功能:允许玩家标记疑似雷的位置(如用'F'表示旗子)。
  • 计时系统:记录玩家完成游戏的时间。

通过以上步骤,可以实现一个基础的命令行扫雷游戏。如需图形界面,可结合EasyX等库进一步开发。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/31 11:47:06

LobeChat开源项目亮点盘点:不只是ChatGPT平替

LobeChat&#xff1a;不只是 ChatGPT 替代品&#xff0c;而是 AI 应用的开放舞台 在今天&#xff0c;几乎每个人都能说出几个大模型的名字——GPT、Claude、Gemini……它们带来了惊人的语言生成能力&#xff0c;也让“AI 聊天”成为日常。但当你真正想把它用进自己的工作流时&a…

作者头像 李华
网站建设 2026/4/7 7:12:52

【毕业设计】SpringBoot+Vue+MySQL 果蔬作物疾病防治系统平台源码+数据库+论文+部署文档

摘要 随着现代农业的快速发展&#xff0c;果蔬作物的疾病防治成为农业生产中的重要环节。传统的疾病防治方法依赖人工经验&#xff0c;效率低下且难以应对大规模种植需求。信息技术的发展为农业病害防治提供了新的解决方案&#xff0c;通过智能化平台实现病害识别、预警和防治策…

作者头像 李华
网站建设 2026/4/14 3:19:34

uvm_sequence机制中重要task的拆解

详细拆解start()任务start()任务不是在uvm_sequence中声明的&#xff0c;而是在uvm_sequence_base中声明的&#xff0c;所以uvm_sequence继承了uvm_sequence_base中的start()方法virtual task start (uvm_sequencer_base sequencer, // 目标sequencer &#xff08;必须…

作者头像 李华
网站建设 2026/4/15 9:44:46

LobeChat在线帮助文档编写规范:让新人快速上手

LobeChat在线帮助文档编写规范&#xff1a;让新人快速上手 在AI技术飞速渗透日常工作的今天&#xff0c;越来越多团队开始尝试引入大语言模型提升效率。但现实往往并不理想&#xff1a;非技术人员面对API密钥、curl命令和Python脚本时一脸茫然&#xff1b;开发人员则疲于搭建前…

作者头像 李华
网站建设 2026/4/13 21:32:32

LobeChat量化模型支持情况:INT4、INT8推理表现对比

LobeChat量化模型支持情况&#xff1a;INT4、INT8推理表现对比 在如今大语言模型&#xff08;LLM&#xff09;快速普及的背景下&#xff0c;越来越多用户希望在本地设备上运行属于自己的AI助手。然而&#xff0c;一个7B或13B参数规模的FP16模型动辄需要10GB以上的内存资源&…

作者头像 李华
网站建设 2026/4/11 11:51:56

类变量和全局变量的作用域分别是什么?

类变量和全局变量的作用域核心差异在于可见范围的边界&#xff1a;全局变量的作用域是「整个模块」&#xff0c;类变量的作用域是「类的命名空间」&#xff08;及子类 / 实例&#xff09;。下面从定义、访问规则、边界限制、示例验证四个维度拆解&#xff0c;让作用域的边界更清…

作者头像 李华