【C】C语言实现扫雷小游戏

简介: 相信大家一定都玩过扫雷小游戏,今天我就带大家来用C语言实现一个简易版的扫雷小游戏。

相信大家一定都玩过扫雷小游戏,今天我就带大家来用C语言实现一个简易版的扫雷小游戏。

这里我们还是需要三个文件来封装我们的写的代码:

  • test.c ----- 用于我们代码的测试,以及游戏整体框架的实现。
  • game .c ------ 用来封装实现我们游戏的相关函数。
  • game.h ------ 主要用来声明游戏的相关的函数。


游戏整体框架的实现

整个框架和我们的三子棋非常的相似,我们玩家再玩完一局后,还可以再来一局,也可以退出游戏,所以i我们还是要使用do…while循环来实现,当然菜单也是不能少的,用来提醒用户的输入。我们还是先把整体的框架搭建起来:

#include"game.h"
void mnue()
{
  printf("*****************************\n");
  printf("******    1. play    ********\n");
  printf("******    0. exit    ********\n");
  printf("*****************************\n");
}
void game(){}
int main()
{
  int input = 0;
  srand((unsigned int)time(NULL));//用于设置随机数的起点,后面设置雷时要使用
  do
  {
    mnue();
    printf("请输入你的选择:>");
    scanf("%d", &input);
    switch (input)
    {
      case 1 :
        game();
        break;
      case 0:
        printf("退出游戏\n");
        break;
      default: 
        printf("选择错误,请重新选择!!\n");
        break;
    }
  } while (input);
  return 0;
}

我们游戏的整体框架搭建好以后,现在就只剩下一个game函数的实现了,这时我们的代码就可以跑起来了,只不过还不能玩游戏。接下来我带大家来实现游戏的相关逻辑。


游戏逻辑的实现

我们扫雷游戏假设我们用的是9*9的格子,我们需要一个棋盘存放雷的信息


字符 0 代表非雷

字符 1 代表雷


这里为什么要这样设计,后面给大家讲!!

所以我们就需要一个9×9的二维字符数组来存放雷的信息。大家都知道我们在排查一次雷以后那个位置不是雷的话,就会显示那个位置周围有多少雷,这时如果那个位置旁边有1个雷的话,就会生成歧义,那个1代表的到底是雷,还是周围雷的个数,针对这种情况,我们干脆直接在来一 个9×9的二维数组,专门来存放周围雷的个数。

我们在排查雷的时候,在排查边界是,很容易出现越界的情况,所以我们直接将我们的数组扩大一圈,但是在打印给玩家是还是中间的9×9的棋盘。

在这里我们不能直接把9写死,应该定义宏来表示棋盘的大小,这样以后方便来扩大棋盘!如下:


#define ROW 9

#define COL 9


#define ROWS ROW+2

#define COLS COL+2


我可以定义两个二维字符数组来表示布置雷的信息,以及排查雷的信息


char mine[ROWS][COLS]; // 雷的信息

char show[ROWS][COLS]; // 排查后的信息


初始化函数

有了两个数组后我们需要一个函数来初始化两个数组,但由于初始化的内容不同,所以我们需要把初始化的内容传进去,所以就多需要一个参数。

void InitBoard(char board[ROWS][COLS], int rows, int cols,char set);

void InitBoard(char board[ROWS][COLS], int rows, int cols, char  set)
{
  for (int i = 0; i < rows; i++)
  {
    for (int j = 0; j < cols; j++)
    {
      board[i][j] = set;
    }
  }
}

打印函数

初始化以后我们要能讲棋盘给打印出来给我们玩家来看,当然我们打印的是show数组,不能给玩家看雷的信息。所以就需要一个打印棋盘的函数(我们给用户看的是9×9的):

void DisplayBoard(char board[ROWS][COLS], int row, int col);

void DisplayBoard(char board[ROWS][COLS], int row, int col)
{
  printf("--------扫雷游戏----------\n");
  // 给每一列加上序号,方便用户排雷
  for (int i = 0; i <= row; i++)
  {
    printf("%d ", i);
  }
  printf("\n");
  for (int i = 1; i <= row; i++)
  {
    printf("%d ", i);  // 给每一行加上序号,方便用户排雷
    for (int j = 1; j <= col; j++)
    {
      printf("%c ", board[i][j]);
    }
    printf("\n");
  }
}

布雷

我们有了打印函数以后就要布置雷的信息了,所以我们还需要一个布置雷的函数:

void SetMine(char mine[ROWS][COLS], int rows, int cols);

void SetMine(char board[ROWS][COLS], int row, int col)
{
  int count = EASY_COUNT; // EASY_COUNT是自己定义的一个宏,来设置游戏难度的
  while (count)
  {
    int x = rand() % row + 1;
    int y = rand() % col + 1;
    if (board[x][y] == '0')  //不能在重复的位置布雷
    {
      board[x][y] = '1';
      count--;
    }
  }
}

排雷

当我们布置好雷以后就剩一个排雷的函数了,我们在排查完雷后,要将信息放如show数组中打印给玩家,所以这里需要将两个数组都传过来。

void FindMine(char mine[ROWS][ROWS], char show[ROWS][COLS], int rows,int cols);

void FindMine(char mine[ROWS][ROWS], char show[ROWS][COLS], int row, int col)
{
  int x = 0;
  int y = 0;
  int win = 0;
  while (win<row*col-EASY_COUNT)
  {
    printf("请输入你要排查的坐标:>");
    scanf("%d %d", &x, &y);
    if (x >= 1 && x <= row && y >= 1 && y <= col)
    {
      if (mine[x][y] == '1')
      {
        printf("你被炸死了!\n");
        break;
      }
      else
      {
        int count = GetMineCount(mine, x, y);
        show[x][y] = count + '0';
        //每次排完后给用户打印棋盘
        DisplayBoard(show, ROW, COL);
        win++;
      }
    }
    else
    {
      printf("坐标非法,重新输入!!\n");
    }
  }
  if (win == row * col - EASY_COUNT)
  {
    printf("玩家赢!\n");
  }
}

这里的win是一个计数器,如过我们用户讲非雷位置都排查过了,那win 就会 等于row * col - EASY_COUNT,这是我们就可以判断玩家赢了,如果踩到雷了就会跳出循环,结束游戏。

这里我们就需要一个GetMineCount来获得排查位置周围雷的个数。


获取周围雷的个数

我们前面设置的雷为字符 1 ,非雷为字符 0,所以我们值需要将周围的8个坐标相加,再减去8个0字符,就可以获取周围雷的个数。

int GetMineCount(char mine[ROWS][COLS],int x, int y)
{
  return (mine[x + 1][y + 1] + mine[x + 1][y] + mine[x - 1][y] + mine[x][y + 1] +
    mine[x + 1][y - 1] + mine[x - 1][y + 1] + mine[x - 1][y - 1] + mine[x][y - 1] -8*'0');
}

game函数的实现

我们有了相关游戏的函数了以后,game就很容易实现了。

void game()
{
  char mine[ROWS][COLS]; // 雷的信息
  char show[ROWS][COLS];  // 排查后的信息
  InitBoard(mine, ROWS, COLS, '0');
  //初始化棋盘
  InitBoard(show, ROWS, COLS, '*');
  //初始化棋盘
  DisplayBoard(show, ROW, COL);
  // 布置雷
  SetMine(mine, ROW, COL);
  //扫雷
  FindMine(mine, show, ROW, COL);
}

这时我们整个逻辑就通了,就可以玩我们的简易版扫雷了。


今天的分享就到这里了,想要完整代码的私信我,感谢大家的关注和支持!!

相关文章
|
机器学习/深度学习 C语言
九/十:《初学C语言》— 扫雷游戏实现和函数递归基础
【8月更文挑战第5天】本篇文章用C语言采用多文件编写实现了一个基础的扫雷游戏(附源码),并讲解了关于函数递归的基础概念及其相对应的习题练习(附源码)
110 1
九/十:《初学C语言》— 扫雷游戏实现和函数递归基础
|
11月前
|
C语言
扫雷游戏(用C语言实现)
扫雷游戏(用C语言实现)
213 0
|
7月前
|
定位技术 C语言
c语言及数据结构实现简单贪吃蛇小游戏
c语言及数据结构实现简单贪吃蛇小游戏
|
12月前
|
定位技术 API C语言
C语言——实现贪吃蛇小游戏
本文介绍了一个基于Windows控制台的贪吃蛇游戏的实现方法。首先,需调整控制台界面以便更好地显示游戏。接着,文章详细描述了如何使用Win32 API函数如`COORD`、`GetStdHandle`、`GetConsoleCursorInfo`等来控制控制台的光标和窗口属性。此外,还介绍了如何利用`GetAsyncKeyState`函数实现键盘监听功能。文中还涉及了`&lt;locale.h&gt;`库的使用,以支持本地化字符显示。
210 1
C语言——实现贪吃蛇小游戏
|
12月前
|
存储 安全 算法
C 语言——实现扫雷小游戏
本文介绍了使用二维数组创建棋盘并实现扫雷游戏的方法。首先,通过初始化数组创建一个9x9的棋盘,并添加行列标识以便操作。接着,利用随机数在棋盘上布置雷。最后,通过判断玩家输入的坐标来实现扫雷功能,包括显示雷的数量和处理游戏胜利或失败的情况。文中提供了完整的代码实现。
153 1
C 语言——实现扫雷小游戏
|
11月前
|
C语言 C++
【C语言】编写“猜数字“小游戏
【C语言】编写“猜数字“小游戏
176 1
|
11月前
|
C语言 开发者
C语言实现猜数字小游戏(详细教程)
C语言实现猜数字小游戏(详细教程)
|
11月前
|
存储 API C语言
【C语言】实践:贪吃蛇小游戏(附源码)(一)
【C语言】实践:贪吃蛇小游戏(附源码)
|
11月前
|
存储 算法 安全
C语言实现扫雷游戏
C语言实现扫雷游戏
|
11月前
|
C语言 定位技术 API
【C语言】实践:贪吃蛇小游戏(附源码)(二)
【C语言】实践:贪吃蛇小游戏(附源码)
【C语言】实践:贪吃蛇小游戏(附源码)(二)