0

0

c语言简单小游戏-扫雷游戏

angryTom

angryTom

发布时间:2020-03-02 10:46:42

|

3997人浏览过

|

来源于php中文网

原创

这篇文章主要为大家详细介绍了c语言实现简单扫雷小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。

c语言简单小游戏-扫雷游戏

c语言简单小游戏-扫雷

本文实例为大家分享了C语言实现扫雷小游戏的具体代码,供大家参考,具体内容如下

#define _CRT_SECURE_NO_WARNINGS
#include 
#include 
#include 
/*
 用 C 语言写一个简单的扫雷游戏
*/
// 1.写一个游戏菜单 Menu()
// 2.开始游戏
 // 1.初始化二维数组 Init_Interface()
 // 2.打印游戏界面 Print_Interface()
 // 3.玩家掀起指定位置 Play() --> 指定输入坐标(判断合法性)
 // 1.判断该位置是否是雷
 // 2.判断是否掀掉所有空地
 // 3.如果掀开的是空地,则判断该空地周围是否有雷
  // 1.如果周围有雷,则统计周围雷的个数
  // 2.如果周围没有雷,则掀开周围除了雷的所有空地,并且统计所掀开空地周围雷的个数
 // 4.更新地图
 // 5.继续 3 的循环
 
//定义全局变量:
//定义扫雷地图的长和宽
#define MAX_ROW 9
#define MAX_COL 9
//定义默认的雷数
#define DEFAULT_MINE 9
//定义两个二维数组,分别存放初始地图和雷阵
char show_map[MAX_ROW + 2][MAX_COL + 2];
char mine_map[MAX_ROW + 2][MAX_COL + 2];
 
//写一个游戏菜单
int Menu() {
 printf("=========\n");
 printf("1.开始游戏\n");
 printf("0.结束游戏\n");
 printf("=========\n");
 printf("请选择游戏菜单选项:");
 int choice = 0;
 while (1) {
 scanf("%d", &choice);
 if (choice != 0 && choice != 1) {
  printf("您的输入有误, 请重新输入\n");
  continue;
 }
 break;
 }
 return choice;
}
 
//开始游戏
//初始化数组
void Init_Interface() {
 for (int row = 0; row < MAX_ROW + 2; row++) {
 for (int col = 0; col < MAX_COL + 2; col++) {
  show_map[row][col] = '*';
 }
 }
 for (int row = 0; row < MAX_ROW + 2; row++) {
 for (int col = 0; col < MAX_COL + 2; col++) {
  mine_map[row][col] = '0';
 }
 }
 int mine_count = DEFAULT_MINE;
 while (mine_count > 0) {
 int row = rand() % MAX_ROW + 1;
 int col = rand() % MAX_COL + 1;
 if (mine_map[row][col] == '1') { //将雷设置为 1
  //此处已经有雷
  continue;
 }
 mine_count--;
 mine_map[row][col] = '1';
 }
}
//打印初始界面
void Print_Interface(char map[MAX_ROW + 2][MAX_COL + 2]) {
 printf("  ");
 for (int col = 1; col <= MAX_COL; col++) {
 printf("%d ", col);
 }
 printf("\n  ");
 for (int col = 1; col <= MAX_COL; col++) {
 printf("--");
 }
 printf("\n");
 for (int row = 1; row <= MAX_ROW ; row++) {
 printf("%02d |", row);
 for (int col = 1; col <= MAX_COL; col++) {
  printf("%c ", map[row][col]);
 }
 printf("\n");
 }
}
//写一个统计周围雷数个数的函数
int Around_Mine_count(int row, int col) {
 return (mine_map[row - 1][col - 1] - '0'
 + mine_map[row - 1][col] - '0'
 + mine_map[row - 1][col + 1] - '0'
 + mine_map[row][col - 1] - '0'
 + mine_map[row][col + 1] - '0'
 + mine_map[row + 1][col - 1] - '0'
 + mine_map[row + 1][col] - '0'
 + mine_map[row + 1][col + 1] - '0');
}
//写一个判断该位置周围是否有雷的函数
int No_Mine(int row, int col) {
 if (Around_Mine_count(row, col) == 0) {
 return 1;
 }
 return 0;
}
//写一个掀开该位置周围空地的函数
void Open_Blank(int row, int col) {
 show_map[row - 1][col - 1] = '0' + Around_Mine_count(row - 1, col - 1);
 show_map[row - 1][col] = '0' + Around_Mine_count(row - 1, col);
 show_map[row - 1][col + 1] = '0' + Around_Mine_count(row - 1, col + 1);
 show_map[row][col - 1] = '0' + Around_Mine_count(row, col - 1);
 show_map[row][col + 1] = '0' + Around_Mine_count(row, col + 1);
 show_map[row + 1][col - 1] = '0' + Around_Mine_count(row + 1, col - 1);
 show_map[row + 1][col] = '0' + Around_Mine_count(row + 1, col);
 show_map[row + 1][col + 1] = '0' + Around_Mine_count(row + 1, col + 1);
}
//写一个判断游戏结束的函数
int Success_Sweep(char show_map[MAX_ROW + 2][MAX_COL + 2]) {
 int count = 0;
 for (int row = 1; row <= MAX_ROW; row++) {
 for (int col = 1; col <= MAX_COL; col++) {
  if (show_map[row][col] == '*') {
  count++;
  }
 }
 }
 if (count == DEFAULT_MINE) {
 return 1;
 }
 return 0;
}
//开始游戏
void StartGame() {
 while (1) {
 printf("请输入您要掀开的坐标:");
 int row = 0;
 int col = 0;
 while (1) {
  scanf("%d %d", &row, &col);
  if (row < 1 || row > MAX_ROW || col < 1 || col > MAX_COL) {
  printf("您的输入有误,请重新输入!\n");
  continue;
  }
  if (show_map[row][col] != '*') {
  printf("该位置已被掀开,请重新选择\n");
  continue;
  }
  break;
 }
 //判断该地方是否有雷
 if (mine_map[row][col] == '1') {
  Print_Interface(mine_map);
  printf("该地方有雷,游戏结束!!!\n");
  break;
 }
 if (No_Mine(row, col)) {
  show_map[row][col] = '0';
  Open_Blank(row, col);
 }
 show_map[row][col] = '0' + Around_Mine_count(row, col);
 //判断是否掀开所有空地
 if (Success_Sweep(show_map) == 1) {
  Print_Interface(mine_map);
  printf("您已成功扫雷!!!\n");
  break;
 }
 system("cls");
 //更新地图
 Print_Interface(show_map);
 }
}
 
int main() {
 if (Menu() == 0) {
 exit(0);
 }
 srand((unsigned int)time(NULL));
 Init_Interface();
 Print_Interface(show_map);
 StartGame();
 
 system("pause");
 return 0;
}

效果图:

2.png

易优游戏竞技公司网站源码1.7.0
易优游戏竞技公司网站源码1.7.0

易优游戏竞技公司网站源码是基于易优cms开发,非常适游戏竞技公司当做官网使用、 程序内核为Thinkphp5.0开发,后台简洁,为企业网站而生。 这是一套安装就能建站的c程序,不定期更新程序BUG,更新网站功能。 我们提供的不仅是模板这么简单,我们还提供程序相关咨询、协助安装等服务。默认不包含小程序插件,需要另外单独购买插件。 模板安装步骤 1、请将安装包ZI

下载

立即学习C语言免费学习笔记(深入)”;

数字代表周围雷的个数

更多C语言教程,推荐观看C语言视频教程

相关文章

C语言速学教程(入门到精通)
C语言速学教程(入门到精通)

C语言怎么学习?C语言怎么入门?C语言在哪学?C语言怎么学才快?不用担心,这里为大家提供了C语言速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
C语言变量命名
C语言变量命名

c语言变量名规则是:1、变量名以英文字母开头;2、变量名中的字母是区分大小写的;3、变量名不能是关键字;4、变量名中不能包含空格、标点符号和类型说明符。php中文网还提供c语言变量的相关下载、相关课程等内容,供大家免费下载使用。

400

2023.06.20

c语言入门自学零基础
c语言入门自学零基础

C语言是当代人学习及生活中的必备基础知识,应用十分广泛,本专题为大家c语言入门自学零基础的相关文章,以及相关课程,感兴趣的朋友千万不要错过了。

619

2023.07.25

c语言运算符的优先级顺序
c语言运算符的优先级顺序

c语言运算符的优先级顺序是括号运算符 > 一元运算符 > 算术运算符 > 移位运算符 > 关系运算符 > 位运算符 > 逻辑运算符 > 赋值运算符 > 逗号运算符。本专题为大家提供c语言运算符相关的各种文章、以及下载和课程。

354

2023.08.02

c语言数据结构
c语言数据结构

数据结构是指将数据按照一定的方式组织和存储的方法。它是计算机科学中的重要概念,用来描述和解决实际问题中的数据组织和处理问题。数据结构可以分为线性结构和非线性结构。线性结构包括数组、链表、堆栈和队列等,而非线性结构包括树和图等。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

259

2023.08.09

c语言random函数用法
c语言random函数用法

c语言random函数用法:1、random.random,随机生成(0,1)之间的浮点数;2、random.randint,随机生成在范围之内的整数,两个参数分别表示上限和下限;3、random.randrange,在指定范围内,按指定基数递增的集合中获得一个随机数;4、random.choice,从序列中随机抽选一个数;5、random.shuffle,随机排序。

603

2023.09.05

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

527

2023.09.20

c语言get函数的用法
c语言get函数的用法

get函数是一个用于从输入流中获取字符的函数。可以从键盘、文件或其他输入设备中读取字符,并将其存储在指定的变量中。本文介绍了get函数的用法以及一些相关的注意事项。希望这篇文章能够帮助你更好地理解和使用get函数 。

645

2023.09.20

c数组初始化的方法
c数组初始化的方法

c语言数组初始化的方法有直接赋值法、不完全初始化法、省略数组长度法和二维数组初始化法。详细介绍:1、直接赋值法,这种方法可以直接将数组的值进行初始化;2、不完全初始化法,。这种方法可以在一定程度上节省内存空间;3、省略数组长度法,这种方法可以让编译器自动计算数组的长度;4、二维数组初始化法等等。

602

2023.09.22

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

45

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Rust 教程
Rust 教程

共28课时 | 4.8万人学习

Kotlin 教程
Kotlin 教程

共23课时 | 2.8万人学习

Go 教程
Go 教程

共32课时 | 4.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号