服务器之家

服务器之家 > 正文

C语言实现简单扫雷小游戏

时间:2021-08-03 13:52     来源/作者:_Saoke

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <windows.h>
#include <time.h>
/*
 用 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;
}

效果图:

C语言实现简单扫雷小游戏

数字代表周围雷的个数

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/qq_42957923/article/details/84144594

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
2021德云社封箱演出完整版 2021年德云社封箱演出在线看
2021德云社封箱演出完整版 2021年德云社封箱演出在线看 2021-03-15
返回顶部