gpt4 book ai didi

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

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 28 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章C语言实现简单扫雷小游戏由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

本文实例为大家分享了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 。

最后此篇关于C语言实现简单扫雷小游戏的文章就讲到这里了,如果你想了解更多关于C语言实现简单扫雷小游戏的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com