我是靠谱客的博主 机灵泥猴桃,这篇文章主要介绍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
int main() { int input = 0; srand((unsigned int)time(NULL)); do { printf("**************************n"); printf("*** 1. play 0. exit ***n"); printf("*** 2. clear ***n"); printf("**************************n"); printf("请选择:>"); scanf("%d", &input); switch (input) { case 1: game();//游戏实现 break; case 2://清屏选项 system("cls"); break; case 0: printf("退出程序!n"); break; default: printf("输入错误,请重新输入!n"); Sleep(1000); system("cls"); break; } } while (input); return 0; }

这里我们用了Windows库函数清屏,如果屏幕上显示的东西太多了,我们可以选择2来清屏,还有一个睡眠函数,如果输出错误会短暂的提示你一秒,告诉你选择错误了。

效果展示图:

制作好菜单那我们开始实现整个游戏的逻辑框架了,定义两个二维数组,一个用于显示,一个用于存放地雷。如果这两个东西都只用一个二维数组的话后面的实现逻辑会比较麻烦所以我选择使用两个二维数组。

复制代码
1
2
char mine[ROWS][COLS] = { 0 };//用于埋雷 char show[ROWS][COLS] = { 0 };//用于游戏的画面显示

有这两个二维数组我们开始初始化

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
//初始化 void initzeboard(char mine[ROWS][COLS], int rows, int cols, char val) { int i = 0; int j = 0; for (i = 0; i < rows; i++) { for (j = 0; j < cols; j++) { mine[i][j] = val; } } }

我遍历整个二维数组来初始化,val这个参数是用于接收这两个二维数组的初始化的内容,如果不用这个val参数我就要再写一个函数封装很麻烦。

接下来,实现个打印棋盘函数来看看我们的初始化是否正确的初始化成我想要的内容

打印棋盘代码:

复制代码
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
//显示棋盘 void Display_board(char mine[ROWS][COLS], int row, int col) { int i = 0; int j = 0; printf(" 扫雷游戏n"); printf("---------------------------------n"); for (j = 0; j <= col; j++) { printf("%d ", j); } printf("n"); for (i = 1; i <= row; i++) { printf("%d ", i); for (j = 1; j <= col; j++) { printf("%c ", mine[i][j]); } printf("n"); } }

接下来看看我们初始化的是否正确:

可以看到它正确的初始化了,全0代表埋雷的二维数组,而*代表的是用户看到的,正常来说,这个埋雷是不需要显示出来的,但是我们需要确认是否正确初始化所以打印出来看看,下一步我们开始埋雷。

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
//埋雷 void random_mine(char mine[ROWS][COLS], int row, int col) { int x = 0; int y = 0; int count = EASILY; while (count) { x = rand() % row + 1; y = rand() % col + 1; if (mine[x][y] == '0')//用于判断是否正确的埋雷,只有我们这没被埋过的雷我们才自减 { mine[x][y] = '1'; count--; } } }

埋好雷的效果:

1代表是雷,0代表步是雷,埋好的雷会被赋值成字符1

埋雷我采用随机函数来帮我埋下雷,弄好这步接来的就是扫雷这很关键。

扫雷代码:

复制代码
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
//扫雷 void mine_sweeping(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col) { int x = 0; int y = 0; while (count < row * col - EASILY) { system("cls"); Display_board(show, COL, ROW); printf("请输入坐标:>"); scanf("%d %d", &x, &y); if ((1 <= x && x <= row) && (1 <= y && y <= col)) { if (mine[x][y] == '0') { int leng = statistics_mine(mine, x, y); show[x][y] = leng + '0'; count++; } else { printf("很遗憾你被炸死了n"); Display_board(mine, ROW, COL); break; } } else { printf("请输入有效数字!n"); } } if (count == row * col - EASILY) { printf("恭喜你扫雷成功!n"); Display_board(mine, ROW, COL); } }

如果玩家输入的坐标是合法的我们就统计它周围有多少雷,统计雷的功能我做成了一个内部函数防止重名。

如果全部没有雷的地方都排查完了,我们就停止循环。然后打印下雷的棋盘让玩家知道哪有雷,如果被炸死了,我们也打印下雷的二维数组让玩家死得瞑目。

统计雷的函数:

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
//统计周围雷的个数 static int statistics_mine(char mine[ROWS][COLS], int x, int y) { return mine[x - 1][y - 1] + mine[x - 1][y] + mine[x - 1][y + 1] + mine[x][y - 1] + mine[x][y + 1] + mine[x + 1][y - 1] + mine[x + 1][y] + mine[x + 1][y + 1] - 8 * '0'; }

根据ASCII码字符1减去字符0就是整形1,所以根据此方法我们就只用把周围的雷全部加起来减去字符零就可以得到周围雷的个数并返回 。

统计雷效果图:

周围没有雷就是0,如果有就显示个数。

通关也会打印所有雷的位置并提示你是否通关

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-m4tO2ZuP-1613214039851)(C:Users86176AppDataRoamingTyporatypora-user-imagesimage-20210213185535958.png)]

头文件:

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#pragma once #include <stdio.h> #include <Windows.h> #include <time.h> #include <stdlib.h> #define ROW 9 #define COL 9 #define ROWS ROW + 2 #define COLS COL + 2 #define EASILY 0//雷的数量 //初始化 void initzeboard(char mine[ROWS][COLS], int rows, int cols, char val); //显示棋盘 void Display_board(char mine[ROWS][COLS], int row, int col); //埋雷 void random_mine(char mine[ROWS][COLS], int row, int col); //扫雷 void mine_sweeping(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);

游戏实现代码:

复制代码
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
#define _CRT_SECURE_NO_WARNINGS 1 #include "Game.h" int count = 0;//统计还剩多少格子没被扫 void game()//游戏实现 { char mine[ROWS][COLS] = { 0 };//用于埋雷 char show[ROWS][COLS] = { 0 };//用于游戏的画面显示 //初始化 initzeboard(show, ROWS, COLS, '*'); initzeboard(mine, ROWS, COLS, '0'); //显示棋盘 Display_board(show, ROW, COL); //Display_board(mine, ROW, COL); //埋雷 random_mine(mine, ROW, COL); //Display_board(mine, ROW, COL); //扫雷 mine_sweeping(mine, show, ROW, COL); } //初始化 void initzeboard(char mine[ROWS][COLS], int rows, int cols, char val) { int i = 0; int j = 0; for (i = 0; i < rows; i++) { for (j = 0; j < cols; j++) { mine[i][j] = val; } } } //显示棋盘 void Display_board(char mine[ROWS][COLS], int row, int col) { int i = 0; int j = 0; printf(" 扫雷游戏n"); printf("---------------------------------n"); for (j = 0; j <= col; j++) { printf("%d ", j); } printf("n"); for (i = 1; i <= row; i++) { printf("%d ", i); for (j = 1; j <= col; j++) { printf("%c ", mine[i][j]); } printf("n"); } } //埋雷 void random_mine(char mine[ROWS][COLS], int row, int col) { int x = 0; int y = 0; int count = EASILY; while (count) { x = rand() % row + 1; y = rand() % col + 1; if (mine[x][y] == '0') { mine[x][y] = '1'; count--; } } } //统计周围雷的个数 static int statistics_mine(char mine[ROWS][COLS], int x, int y) { return mine[x - 1][y - 1] + mine[x - 1][y] + mine[x - 1][y + 1] + mine[x][y - 1] + mine[x][y + 1] + mine[x + 1][y - 1] + mine[x + 1][y] + mine[x + 1][y + 1] - 8 * '0'; } //扫雷 void mine_sweeping(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col) { int x = 0; int y = 0; while (count < row * col - EASILY) { system("cls"); Display_board(show, COL, ROW); printf("请输入坐标:>"); scanf("%d %d", &x, &y); if ((1 <= x && x <= row) && (1 <= y && y <= col)) { if (mine[x][y] == '0') { int leng = statistics_mine(mine, x, y); show[x][y] = leng + '0'; count++; } else { printf("很遗憾你被炸死了n"); Display_board(mine, ROW, COL); break; } } else { printf("请输入有效数字!n"); } } if (count == row * col - EASILY) { printf("恭喜你扫雷成功!n"); Display_board(mine, ROW, COL); } }

主函数代码:

复制代码
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
#define _CRT_SECURE_NO_WARNINGS 1 #include "Game.h" extern void game(); int main() { int input = 0; srand((unsigned int)time(NULL)); do { printf("**************************n"); printf("*** 1. play 0. exit ***n"); printf("*** 2. clear ***n"); printf("**************************n"); printf("请选择:>"); scanf("%d", &input); switch (input) { case 1: game();//游戏实现 break; case 2://清屏选项 system("cls"); break; case 0: printf("退出程序!n"); break; default: printf("输入错误,请重新输入!n"); Sleep(1000); system("cls"); break; } } while (input); return 0; }

到此这篇关于C语言实现扫雷游戏详细代码实例的文章就介绍到这了,更多相关C语言实现扫雷游戏内容请搜索靠谱客以前的文章或继续浏览下面的相关文章希望大家以后多多支持靠谱客!

最后

以上就是机灵泥猴桃最近收集整理的关于C语言实现扫雷游戏详细代码实例的全部内容,更多相关C语言实现扫雷游戏详细代码实例内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(97)

评论列表共有 0 条评论

立即
投稿
返回
顶部