扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
这篇文章将为大家详细讲解有关怎么利用C语言实现简易版扫雷,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
创新互联公司是一家专业提供新华企业网站建设,专注与成都网站设计、做网站、H5响应式网站、小程序制作等业务。10年已为新华众多企业、政府机构等服务。创新互联专业网站制作公司优惠进行中。首先我们要构建好雷盘的样子,我们理所当然想到利用二维数组。那么请注意:因为我们每一次随机生成的雷盘不能展示给用户,所以显示盘与雷盘要分开,那么我们在这里要用到两个二维数组。一个是雷盘,用来记录随机生成雷的布局,另一个是显示盘,初始化全为*,让用户来扫雷。
具体功能:
先由电脑随机生成雷的分布。
玩家通过输入坐标来选择点。
玩家选择对应点后,对应点将显示周围雷的个数(以该点为中心的一个九宫格)。
玩家需要根据这个个数,自己推断出有雷的地方,不能输入有雷的对应坐标,只能输入没雷的对应坐标。
当输入坐标对应点有雷时,炸“死”,游戏结束。当剩下未选中的点的个数等于总共布下的雷的个数时,游戏胜利。
实现功能的函数:
1.菜单函数,必不可少,是展示给用户的第一界面,这个比较简陋,后期可以考虑做一些fashion一点的。
void Menu() { printf("##########################\n"); printf("#####choose 1 to play#####\n"); printf("#####choose 0 to exit#####\n"); printf("Please input your select here:>\n"); }
2.随机生成雷函数,那么对应雷的横竖坐标就是需要随机生成的数。如果大家看过我之前的三子棋就知道,在这里关于随机生成用到了函数GetIndex,算是一个小优化。
void SetMine(char mine_board[][COL], int row, int col) { srand((unsigned long)time(NULL)); int mine_num = MINES; while (mine_num) { int i_index = GetIndex(1,col-2);//生成1~10的随机数 int j_index = GetIndex(1,col-2); if (mine_board[i_index][j_index] == '0') { mine_board[i_index][j_index] = '1'; mine_num--; } } }
3.GetIndex函数,这里要注意start和end表示的是生成的随机数的范围。之前我们 如果用rand生成0~10的随机数,就直接rand%10,但是如果是5 ~10呢?所以我们用(end-start+1)得到的是0 ~end的范围,再加一个start,就能到到start ~end的范围。
static int GetIndex(int start, int end)//static修饰 代表该函数只能在本文件内部使用 { return rand() % (end - start + 1) + start; }
4.得到一个点周围雷的数量函数,这里要注意,我写的这个函数的返回值是整型,但得到的mine_board的和是字符型,那么要通过8-'0'来转换一下。
int GetMineNum(char mine_board[][COL], int i, int j) { return mine_board[i-1][j-1]+mine_board[i-1][j]+ mine_board[i-1][j+1]+ \ mine_board[i][j-1]+ mine_board[i][j+1]+ \ mine_board[i+1][j-1]+mine_board[i+1][j]+ mine_board[i+1][j+1]-8*'0';//整型 }
5.显示雷盘函数
void ShowBoard(char show_board[][COL], int row, int col) { int i = 0; int j = 0; printf(" "); for (i = 1; i <= col-2; i++) { printf("%d ", i); } printf("\n"); for (i = 1; i <= col - 1; i++) { printf("----"); } printf("\n"); for (i = 1; i <=row - 2; i++) { printf("%-2d|", i); for (j = 1; j <=col - 2; j++) { printf(" %c |", show_board[i][j]); } printf("\n"); int k = 1; for (k = 1; k <= col - 1; k++) { printf("----"); } printf("\n"); } }
6.进行游戏函数,以total作为一个衡量标准。输入坐标,判断是否为雷的位置,是则游戏结束,不是则总的方块数减1,继续输入坐标。
void PlayGame(char show_board[][COL], char mine_board[][COL], int row, int col) { int i = 0; int j = 0; int total = (ROW - 2)*(COL - 2); while (1) { ShowBoard(show_board, row, col); printf("Please enter your pos"); scanf("%d%d", &i, &j); if (i >= 1 && i < row - 2 && j >= 1 && j < col - 2) { if (mine_board[i][j] == '0') { int num = GetMineNum(mine_board, i, j); show_board[i][j] = num + '0'; total--; } else { ShowBoard(mine_board, row, col); printf("Game over!you lose!:(\n"); break; } } else { printf("Error!Try again!\n"); continue; } if (total == MINES) { printf("You win:)!\n"); break; } } }
7.Game函数,初始化两个盘,主要调用了前面的函数,对函数的一个整合,来贯穿一下整个流程。
void Game() { char show_board[ROW][COL]; char mine_board[ROW][COL]; memset(show_board, '*', sizeof(show_board)); memset(mine_board, '0', sizeof(mine_board)); SetMine(mine_board, ROW, COL); PlayGame(show_board, mine_board, ROW, COL); }
这里还是采用了文件的形式,分为函数声明,函数定义,主函数。
函数声明 Mine.h
#ifndef _MINE_H_ #define _MINE_H_ #include#include #include #include #define ROW 12 #define COL 12 #define MINES 20 void Menu(); void Game(); int GetIndex(int start, int end); void SetMine(char mine_board[][COL], int row, int col); int GetMineNum(char mine_board[][COL], int i, int j); void ShowBoard(char show_board[][COL], int row, int col); void PlayGame(char show_board[][COL], char mine_board[][COL], int row, int col); #endif
函数定义 Mine.c
#include"Mine.h" void Menu() { printf("##########################\n"); printf("#####choose 1 to play#####\n"); printf("#####choose 0 to exit#####\n"); printf("Please input your select here:>\n"); } static int GetIndex(int start, int end)//static修饰 代表该函数只能在本文件内部使用 { return rand() % (end - start + 1) + start; } //随机生成雷 void SetMine(char mine_board[][COL], int row, int col) { srand((unsigned long)time(NULL)); int mine_num = MINES; while (mine_num) { int i_index = GetIndex(1,col-2); int j_index = GetIndex(1,col-2); if (mine_board[i_index][j_index] == '0') { mine_board[i_index][j_index] = '1'; mine_num--; } } } //得到一个点周围雷的数量 int GetMineNum(char mine_board[][COL], int i, int j) { return mine_board[i-1][j-1]+mine_board[i-1][j]+ mine_board[i-1][j+1]+ \ mine_board[i][j-1]+ mine_board[i][j+1]+ \ mine_board[i+1][j-1]+mine_board[i+1][j]+ mine_board[i+1][j+1]-8*'0';//整型 } //显示雷盘 void ShowBoard(char show_board[][COL], int row, int col) { int i = 0; int j = 0; printf(" "); for (i = 1; i <= col-2; i++) { printf("%d ", i); } printf("\n"); for (i = 1; i <= col - 1; i++) { printf("----"); } printf("\n"); for (i = 1; i <=row - 2; i++) { printf("%-2d|", i); for (j = 1; j <=col - 2; j++) { printf(" %c |", show_board[i][j]); } printf("\n"); int k = 1; for (k = 1; k <= col - 1; k++) { printf("----"); } printf("\n"); } } void PlayGame(char show_board[][COL], char mine_board[][COL], int row, int col) { int i = 0; int j = 0; int total = (ROW - 2)*(COL - 2); while (1) { ShowBoard(show_board, row, col); printf("Please enter your pos"); scanf("%d%d", &i, &j); if (i >= 1 && i < row - 2 && j >= 1 && j < col - 2) { if (mine_board[i][j] == '0') { int num = GetMineNum(mine_board, i, j); show_board[i][j] = num + '0'; total--; } else { ShowBoard(mine_board, row, col); printf("Game over!you lose!:(\n"); break; } } else { printf("Error!Try again!\n"); continue; } if (total == MINES) { printf("You win:)!\n"); break; } } } void Game() { char show_board[ROW][COL]; char mine_board[ROW][COL]; memset(show_board, '*', sizeof(show_board)); memset(mine_board, '0', sizeof(mine_board)); SetMine(mine_board, ROW, COL); PlayGame(show_board, mine_board, ROW, COL); }
主函数 main.c
#include"Mine.h" int main() { int select = 0; int quit = 0; while (!quit) { Menu(); scanf("%d", &select); switch (select) { case 1: Game(); break; case 0: printf("OK,byebye!\n"); quit = 1; break; default: printf("Error!input again!\n"); break; } } system("pause"); return 0; }
运行展示界面:
关于“怎么利用C语言实现简易版扫雷”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流