七步手把手教你实现扫雷游戏
- c语言实现扫雷游戏
- 一. 整体思路
- 二. 设计棋盘以及初始化
- 三. 埋雷
- 四. 扫雷
c语言实现扫雷游戏
一. 整体思路
和上一篇文章的三子棋一样 第一步咱们创建三个工程文件
game.c 文件 用来实现游戏的函数定义
game.h 文件 用来声明函数以及需要的头文件
test.c文件 用来测试函数的运行调试 并且做一些优化
首先 要进行扫雷游戏 咱先搞两个棋盘
一个棋盘里面放雷以及安全区域的的位置
一个棋盘里面放’#'用来让玩家排查
至于为什么要这样子做呢 后面的详细介绍会解释
然后第二步 我们就要开始布置雷了
第三步 开始扫雷
判断成功失败条件
二. 设计棋盘以及初始化
第一步 我们先把需要用到的所有头文件先再game.h里面声明了
然后在分别在game.c以及test.c里面声明game.h
想想看我们怎么才能设计出来一个棋盘呢?
首先要有行和列
上网查一下 简单难度的扫雷一般是9x9的格子 那我们就先设计一个9x9的棋盘吧
但是呢 根据扫雷的规则 我们要排查周边的9个空格 因此呢 设计一个9x9的棋盘很容易越界
这个时候有些聪明的同学就想到了 我们可以设计一个11 x 11的棋盘 但是只使用中间9 x 9的部分
这样就能完全规避数组指针越界的问题啦
代码如下
char mine[row][col] = { 0 };
char show[row][col] = { 0 };
其中row被定义为9
col也被定义为9
那么我们接着下一步 初始化棋盘
代码如下:
void init_board(char board[row][col],int x,int y, char ret)
{int i = 0;int j = 0;for ( i = 0; i < x; i++){for ( j = 0; j < y; j++){board[i][j]=ret;}}
}void show_board(char board[row][col], int x, int y)
{int i = 0;int j = 0;for ( i = 0; i < x; i++){printf("\n");for ( j = 0; j < y; j++){printf("%c ", board[i][j]);}}printf("\n");
}
效果图如下
但是呢 我们只需要一个内部9x9的棋盘
所以我们将代码优化一下
优化后代码如下
void show_board(char board[row][col], int x, int y)
{int i = 0;int j = 0;for ( j = 0; j < y-1; j++){printf("%d ", j);}printf("\n");for ( i = 1; i < x-1; i++){printf("%d ", i);for ( j = 1; j < y-1; j++){printf("%c ", board[i][j]);}printf("\n");}printf("\n");}
那么这样子 我们设计棋盘和初始化就全部完成啦
三. 埋雷
埋雷的思路和上一篇文章里面电脑下棋的思路一样
都是产生随机数
然后将数组里面的十个元素赋值字符‘1’ 意思是 这块地址就是雷了
代码参考如下
void set_board(char board[row][col],int x,int y)
{int count = 10;while (count){int i = rand() % 9 + 1;int j = rand() % 9 + 1;if (board[i][j]=='0'){board[i][j] = '1';count--;}}
}
四. 扫雷
要实现扫雷的思路大概讲解一下
1 我们创建一个函数 里面输入mine数组和show数组
2 让我们开始选坐标
3 首先判断这个坐标有没有雷 如果有雷直接game over
4 其次判断这个坐标是否已经输入过
5 如果都没有的话 接下来进行两件事1 判断这个元素周边有多少个雷
2 将show数组中的这个元素赋值成周边雷的个数
关于如何判断这个元素周边有多少个雷 这个理教给大家一个小知识
字符串数字减去字符串‘0’的ascll码值就是这个数字的ascll码值
关于上面一句话的实现代码如下
int get_mine_count(char mine[row][col], int x, int y)
{return (mine[x - 1][y] +mine[x - 1][y - 1] +mine[x][y - 1] +mine[x + 1][y - 1] +mine[x + 1][y] +mine[x + 1][y + 1] +mine[x][y + 1] +mine[x - 1][y + 1] - 8 * '0');
}
总体实现代码如下
void Find_mine(char mine[row][col],char show[row][col], int b, int c)
{int x = 0;int y = 0;int count = 71;while (count){printf("请输入要排查雷的坐标:>\n");scanf("%d %d", &x, &y);if (x >= 1 && x <= 9 && y >= 1 && y <= 9){if (show[x][y] == '#'){if (mine[x][y] == '1'){printf("很遗憾 你被炸死了");show_board(mine, 11, 11);break;}// 计算有多少个雷else{int count = get_mine_count(mine, x, y);show[x][y] = count + '0';// 展示show棋盘show_board(show, 11, 11);count--;}}else{printf("该坐标已被占用");}}else{printf("坐标非法,请重新输入 ");}}if (count==0){printf("排雷成功");}
}
实现函数的所有代码如下
test.c
#define _CRT_SECURE_NO_WARNINGS 1
#include "game.h"int main()
{srand((unsigned int)time(NULL));char mine[row][col] = { 0 };char show[row][col] = { 0 };// 初始化两个数组init_board(mine, 11, 11, '0');init_board(show, 11, 11, '#'); 打印两个数组 show_board(mine, 11, 11);show_board(show, 11, 11);// 布雷 并且展示一下set_board(mine, 11, 11);//show_board(mine, 11, 11);// 展示排雷Find_mine(mine, show, 11, 11);return 0;
}
game.c
#define _CRT_SECURE_NO_WARNINGS 1
#include "game.h"
void init_board(char board[row][col],int x,int y, char ret)
{int i = 0;int j = 0;for ( i = 0; i < x; i++){for ( j = 0; j < y; j++){board[i][j]=ret;}}
}void show_board(char board[row][col], int x, int y)
{int i = 0;int j = 0;for ( j = 0; j < y-1; j++){printf("%d ", j);}printf("\n");for ( i = 1; i < x-1; i++){printf("%d ", i);for ( j = 1; j < y-1; j++){printf("%c ", board[i][j]);}printf("\n");}printf("\n");}void set_board(char board[row][col],int x,int y)
{int count = 10;while (count){int i = rand() % 9 + 1;int j = rand() % 9 + 1;if (board[i][j]=='0'){board[i][j] = '1';count--;}}
}int get_mine_count(char mine[row][col], int x, int y)
{return (mine[x - 1][y] +mine[x - 1][y - 1] +mine[x][y - 1] +mine[x + 1][y - 1] +mine[x + 1][y] +mine[x + 1][y + 1] +mine[x][y + 1] +mine[x - 1][y + 1] - 8 * '0');
}void Find_mine(char mine[row][col],char show[row][col], int b, int c)
{int x = 0;int y = 0;int count = 71;while (count){printf("请输入要排查雷的坐标:>\n");scanf("%d %d", &x, &y);if (x >= 1 && x <= 9 && y >= 1 && y <= 9){if (show[x][y] == '#'){if (mine[x][y] == '1'){printf("很遗憾 你被炸死了");show_board(mine, 11, 11);break;}// 计算有多少个雷else{int count = get_mine_count(mine, x, y);show[x][y] = count + '0';// 展示show棋盘show_board(show, 11, 11);count--;}}else{printf("该坐标已被占用");}}else{printf("坐标非法,请重新输入 ");}}if (count==0){printf("排雷成功");}
}
game.h
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#include<windows.h>
#include<time.h>
#define ROW 9
#define COL 9
#define row ROW+2
#define col COL+2
void init_board(char board[row][col], int x, int y, char ret);
void show_board(char board[row][col], int x, int y);
void set_board(char board[row][col], int x, int y);
int get_minr_count(char mine[row][col], int x, int y);
void Find_mine(char mine[row][col], char show[row][col], int x, int y);
以上就是手把手教你扫雷的全部内容啦
大家可以试着自己敲一遍代码试试
由于博主本人知识比较浅薄 难免出现错误 希望大佬看到之后能够不吝赐教 在评论区或者私信指正