广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >用C语言实现简单扫雷游戏
  • 589
分享到

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

2024-04-02 19:04:59 589人浏览 薄情痞子
摘要

前言 本文写的是用C语言实现扫雷,用递归实现周围一圈无雷时,自动继续判断下一圈是否有雷,直到四周有地雷的信息。 最终结果展示 初始游戏界面 四周无地雷继续向外展开,直到出现地雷信息

前言

本文写的是用C语言实现扫雷,用递归实现周围一圈无雷时,自动继续判断下一圈是否有雷,直到四周有地雷的信息。

最终结果展示

初始游戏界面

四周无地雷继续向外展开,直到出现地雷信息

项目创建

本项目由test.c,game.c,game.h构成,其中test.c用于测试,存放main函数,game.c存放具体函数定义,game.h引用头文件、定义预定义符号以及存放函数声明。

项目构思及实现

1.main函数

预期程序运行时先出现选择界面,玩家输入1进入游戏,输入0退出游戏,一次游戏结束后,再次弹出选择界面,于是考虑do while循环

下面是main函数的代码


int main()
{
 int input;
 srand((unsigned)time(NULL));
 do
 {
  menu();
  printf("请选择:>");
  scanf("%d", &input);
  switch (input)
  {
  case 1:
   game();
   break;
  case 0:
   printf("退出游戏\n");
   break;
  default:
   printf("选择错误,请重新选择!\n");
   break;
  }
 } while (input);

 return 0;
}

2.menu函数


void menu()
{
 printf("********************************\n");
 printf("***********  1.play  ***********\n");
 printf("***********  0.exit  ***********\n");
 printf("********************************\n");
}

3.game函数

game函数是本项目实现的关键,根据扫雷的游戏界面的特点想到用字符数组储存信息,布雷功能由随机数实现,考虑到雷区信息在一局游戏里一直不变,想到用一个数组保存布雷信息,一个数组用于保存扫雷信息并用于打印。最关键的是扫雷功能的实现。

game函数的构架

1.定义两个数组
2.初始化数组
3.布雷
4.扫雷

下面是game函数的代码


void game()
{
 char mine[ROWS][COLS] = { 0 };//存放雷的信息
 char show[ROWS][COLS] = { 0 };//存放排雷提示信息

 InitBoard(mine, ROWS, COLS, '0');
 InitBoard(show, ROWS, COLS, '*');

 //布雷
 SetMine(mine, ROW, COL);
 //DisplayBoard(mine, ROW, COL);//测试用,待会儿删
 DisplayBoard(show, ROW, COL);

 //扫雷
 FindMine(mine, show, ROW, COL);
}

4.InitBoard函数

mine数组里,0代表无雷,因此初始化时全部置为字符0;
show数组先全部置为*,扫雷时根据周围地雷数量替换数组内容为对应的数字字符。
下面是数组初始化函数InitBoard的代码


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

5.SetMine布置地雷函数

接下来是实现布雷函数SetMine,下面是代码


void SetMine(char board[ROWS][COLS], int row, int col)
{
 int count = EASY_COUNT;
 while (count)
 {
  int x = rand() % row + 1;//x代表第几行
  int y = rand() % col + 1;//y代表第几列
  if (board[x][y] != '1')//不能在同一个地方重复放雷
  {
   board[x][y] = '1';
   count--;
  }
 }
}

6.DisplayBoard打印界面函数

布置好地雷后需要打印界面,为了便于玩家确定坐标,在边界打印了行标和列标,这一功能由DisplayBoard实现


void DisplayBoard(char board[ROWS][COLS], int row, int col)
{
 int i = 0;
 printf("--------------------------\n");
 for (i = 0; i <= 9; i++)
 {
  printf("%d ", i);
 }
 printf("\n");
 for (i = 1; i <= row; i++)
 {
  int j;
  printf("%d ", i);
  for (j = 1; j <= col; j++)
  {
   printf("%c ", board[i][j]);
  }
  printf("\n");
 }
 printf("-------------------------\n");
}

7.FindMine扫雷函数

接下来是最关键的扫雷函数FineMine的实现,设计思路是根据数组mine判断用户输入坐标处是否有雷,有雷则游戏结束;无雷,则通过一个GetMineCount函数确定该位置周围8个位置有几个雷,根据返回结果,把show数组内容换成相应数字字符。同时,需要定义一个变量win来确定游戏是否结束,每确定一个位置无雷win加一,当win=总格子数-地雷数时,退出游戏。

需要注意的是,用户的输入需要在一定区域内,这里用if语句不难实现。

下面是代码


void FindMine(char mine[ROWS][COLS], 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");
    DisplayBoard(mine, ROW, COL);
    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");
  DisplayBoard(mine, ROW, COL);
 }
}

8.GetMineCount数地雷函数

接下来只要实现GetMineCount就可以实现扫雷的基本功能了
需要注意的是,mine数组里原先放的是字符0(代表无地雷)和字符1(代表有地雷),想到得到地雷的个数,这里的做法是先把周围8个数组的内容相加,再减去8个字符'0'即可。
但这时我们发现,当扫雷位置在边界时,会发生数组越界的情况,所以我们采用了定义数组比游戏区域大一圈的做法。
这里游戏界面设计成9*9。当然,由于各功能之间相互独立,只要在game.h中改变ROWS和COLS的值便可实现更大的游戏界面。

所以数组mine和show都是11*11的数组(show的作用主要是用来打印,设计成9*9也无妨,但为了与mine对应,这里设计成一样大)。

下面是GetMineCount的代码


int GetMineCount(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');
}

9.Unfold展开函数

有了以上代码,扫雷已经可以玩了,但是每次只能扫一个雷,我们期望当一个位置周围八个位置都无地雷时,自动判断这八个位置的周围八个位置的地雷信息,这个功能用一个Unfold函数递归实现
需要注意的是,为了避免出现无限递归的情况,需要对扫过雷的位置做出标记,于是考虑把扫过雷的位置换成空格。
另一个去要注意的点是,为了避免数组越界,递归之前还要对坐标进行判断
这时,由于每次扫出无地雷位置的数量不确定,所以把win的地址传给函数,每确定一个位置win+1。

Unfold的递归条件:

  • 四周无地雷
  • 坐标不越界
  • 该位置没有判断过

下面是代码


void Unfold(char mine[ROWS][COLS], char show[ROWS][COLS], int x, int y,int *win)
{
 if (show[x][y] =='*')
 {
  *win+=1;
  int count = GetMineCount(mine, x, y);
  if (count == 0)
  {
   show[x][y] = ' ';
   if(((x-1)>=1)&&((x-1)<=9)&&((y-1)>=1)&&((y-1)<=9))
    Unfold(mine, show, x - 1, y - 1,win);
   if(((x - 1) >= 1) && ((x - 1) <= 9)&&(y>=1)&&(y<=9))
    Unfold(mine, show, x - 1, y,win);
   if(((x - 1) >= 1) && ((x - 1) <= 9)&&((y+1)>=1)&&((y+1)<=9))
    Unfold(mine, show, x - 1, y + 1,win);
   if((x>=1)&&(x<=9)&& ((y - 1) >= 1) && ((y - 1) <= 9))
    Unfold(mine, show, x, y - 1,win);
   if((x >= 1) && (x <= 9)&& ((y + 1) >= 1) && ((y + 1) <= 9))
    Unfold(mine, show, x, y + 1,win);
   if(((x+1)>=1)&&((x+1)<=9)&& ((y - 1) >= 1) && ((y - 1) <= 9))
    Unfold(mine, show, x + 1, y - 1,win);
   if(((x + 1) >= 1) && ((x + 1) <= 9)&& (y >= 1) && (y <= 9))
    Unfold(mine, show, x + 1, y,win);
   if(((x + 1) >= 1) && ((x + 1) <= 9)&& ((y + 1) >= 1) && ((y + 1) <= 9))
    Unfold(mine, show, x + 1, y + 1,win);
  }
  else
  {
   show[x][y] = count + '0';
   return;
  }
 }
}

FindMine也需要做出相应改变


void FindMine(char mine[ROWS][COLS], 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");
    DisplayBoard(mine, ROW, COL);
    break;
   }
   else
   {
    Unfold(mine, show, x, y,&win);
    DisplayBoard(show, ROW, COL);
   }
  }
  else
  {
   printf("坐标非法,请重新输入\n");
  }
 }
 if (win == row * col - EASY_COUNT)
 {
  printf("恭喜,排雷成功\n");
  DisplayBoard(mine, ROW, COL);
 }
}

代码整合

test.c


#define _CRT_SECURE_NO_WARNINGS 
#include"game.h"

void menu()
{
 printf("********************************\n");
 printf("***********  1.play  ***********\n");
 printf("***********  0.exit  ***********\n");
 printf("********************************\n");
}

void game()
{
 char mine[ROWS][COLS] = { 0 };//存放雷的信息
 char show[ROWS][COLS] = { 0 };//存放排雷提示信息

 InitBoard(mine, ROWS, COLS, '0');
 InitBoard(show, ROWS, COLS, '*');

 //布雷
 SetMine(mine, ROW, COL);
 //DisplayBoard(mine, ROW, COL);//测试用,待会儿删
 DisplayBoard(show, ROW, COL);

 //扫雷
 FindMine(mine, show, ROW, COL);
}

int main()
{
 int input;
 srand((unsigned)time(NULL));
 do
 {
  menu();
  printf("请选择:>");
  scanf("%d", &input);
  switch (input)
  {
  case 1:
   game();
   break;
  case 0:
   printf("退出游戏\n");
   break;
  default:
   printf("选择错误,请重新选择!\n");
   break;
  }
 } while (input);

 return 0;
}

game.c


#define _CRT_SECURE_NO_WARNINGS 
#include"game.h"

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

void DisplayBoard(char board[ROWS][COLS], int row, int col)
{
 int i = 0;
 printf("--------------------------\n");
 for (i = 0; i <= 9; i++)
 {
  printf("%d ", i);
 }
 printf("\n");
 for (i = 1; i <= row; i++)
 {
  int j;
  printf("%d ", i);
  for (j = 1; j <= col; j++)
  {
   printf("%c ", board[i][j]);
  }
  printf("\n");
 }
 printf("-------------------------\n");
}

void SetMine(char board[ROWS][COLS], int row, int col)
{
 int count = EASY_COUNT;
 while (count)
 {
  int x = rand() % row + 1;//x代表第几行
  int y = rand() % col + 1;//y代表第几列
  if (board[x][y] != '1')//不能在同一个地方重复放雷
  {
   board[x][y] = '1';
   count--;
  }
 }
}

int GetMineCount(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 Unfold(char mine[ROWS][COLS], char show[ROWS][COLS], int x, int y,int *win)
{
 if (show[x][y] =='*')
 {
  *win+=1;
  int count = GetMineCount(mine, x, y);
  if (count == 0)
  {
   show[x][y] = ' ';
   if(((x-1)>=1)&&((x-1)<=9)&&((y-1)>=1)&&((y-1)<=9))
    Unfold(mine, show, x - 1, y - 1,win);
   if(((x - 1) >= 1) && ((x - 1) <= 9)&&(y>=1)&&(y<=9))
    Unfold(mine, show, x - 1, y,win);
   if(((x - 1) >= 1) && ((x - 1) <= 9)&&((y+1)>=1)&&((y+1)<=9))
    Unfold(mine, show, x - 1, y + 1,win);
   if((x>=1)&&(x<=9)&& ((y - 1) >= 1) && ((y - 1) <= 9))
    Unfold(mine, show, x, y - 1,win);
   if((x >= 1) && (x <= 9)&& ((y + 1) >= 1) && ((y + 1) <= 9))
    Unfold(mine, show, x, y + 1,win);
   if(((x+1)>=1)&&((x+1)<=9)&& ((y - 1) >= 1) && ((y - 1) <= 9))
    Unfold(mine, show, x + 1, y - 1,win);
   if(((x + 1) >= 1) && ((x + 1) <= 9)&& (y >= 1) && (y <= 9))
    Unfold(mine, show, x + 1, y,win);
   if(((x + 1) >= 1) && ((x + 1) <= 9)&& ((y + 1) >= 1) && ((y + 1) <= 9))
    Unfold(mine, show, x + 1, y + 1,win);
  }
  else
  {
   show[x][y] = count + '0';
   return;
  }
 }
}

void FindMine(char mine[ROWS][COLS], 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");
    DisplayBoard(mine, ROW, COL);
    break;
   }
   else
   {
    //int count = GetMineCount(mine, x, y);
    //show[x][y] = count + '0';
    //DisplayBoard(show, ROW, COL);
    //win++;
    
    Unfold(mine, show, x, y,&win);
    DisplayBoard(show, ROW, COL);
   }
  }
  else
  {
   printf("坐标非法,请重新输入\n");
  }
 }
 if (win == row * col - EASY_COUNT)
 {
  printf("恭喜,排雷成功\n");
  DisplayBoard(mine, ROW, COL);
 }
}

game.h


#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<time.h>

#define ROW 9
#define COL 9
#define ROWS 11
#define COLS 11
#define EASY_COUNT 10

void InitBoard(char board[ROWS][COLS],int row,int col,char set);
void DisplayBoard(char board[ROWS][COLS], int row, int col);
void SetMine(char board[ROWS][COLS], int row, int col);
void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);
void Unfold(char mine[ROWS][COLS], char show[ROWS][COLS], int x, int y);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: 用C语言实现简单扫雷游戏

本文链接: https://www.lsjlt.com/news/131465.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 用C语言实现简单扫雷游戏
    前言 本文写的是用C语言实现扫雷,用递归实现周围一圈无雷时,自动继续判断下一圈是否有雷,直到四周有地雷的信息。 最终结果展示 初始游戏界面 四周无地雷继续向外展开,直到出现地雷信息...
    99+
    2022-11-12
  • C语言扫雷游戏的简单实现
    今天来用c语言做一个扫雷功能的简单实现,首先创建一个test.c来用于在写代码的途中测试扫雷代码,game.h来存放实现扫雷函数需要用到的头文件,game.c来存放最终的成品。 首先...
    99+
    2022-11-12
  • 用C语言简单实现扫雷小游戏
    本文实例为大家分享了C语言简单实现扫雷小游戏的具体代码,供大家参考,具体内容如下 设计思路 1. 定义两个二维数组,一个存放炸弹信息,一个隐藏信息后向玩家展示。 2. 玩家每一次选择...
    99+
    2022-11-12
  • 用C语言实现简单扫雷小游戏
    前言 今天学习了制作简易扫雷游戏,代码如下 提示:以下是本篇文章正文内容,下面案例可供参考 一、函数头文件(函数声明) 代码如下(示例): #pragma once #defin...
    99+
    2022-11-12
  • C语言版简单扫雷游戏
    本文实例为大家分享了C语言版的简单扫雷游戏,供大家参考,具体内容如下 思想 我们在设计的时候,首先将其分为三个部分,分别为头文件game.h游戏界面及主要实现的功能函数部分test....
    99+
    2022-11-12
  • 基于C语言实现简单扫雷游戏
    在每一个电脑里总有一个固定的小游戏-扫雷,那今天就让我们一起来实现下扫雷。 1.主函数的构建 int main() { int input = 0; do { me...
    99+
    2022-11-12
  • C语言实现扫雷小游戏简单版
    本文实例为大家分享了C语言实现扫雷小游戏的具体代码,供大家参考,具体内容如下 在vs2019创建新项目,然后添加两个源文件test.c和game.c,接着创建一个头文件game.h。...
    99+
    2022-11-12
  • 怎么用C语言实现简单扫雷游戏
    本篇内容介绍了“怎么用C语言实现简单扫雷游戏”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.主函数的构建int main(){&...
    99+
    2023-06-25
  • 基于C语言实现简单的扫雷游戏
    目录效果展示开始的界面选择标记地雷或者选择踩坐标在输入坐标处输入0 0结束游戏踩到炸弹,出现炸弹位置胜利代码test.cgame.hgame扫雷.c效果展示 开始的界面 输入0结束...
    99+
    2022-11-13
  • C语言实现一个简单的扫雷游戏
    前言 扫雷跟上一篇文章的三子棋一样,是C语言基础知识的综合运用的实例,对于巩固我们的基础知识非常重要,同时扫雷作为C语言的一个小项目,锻炼我们的编程思维,也是一个不可多得的实践。 提...
    99+
    2022-11-12
  • C语言如何实现简单扫雷小游戏
    本篇内容主要讲解“C语言如何实现简单扫雷小游戏”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言如何实现简单扫雷小游戏”吧!前言今天学习了制作简易扫雷游戏,代码如下提示:以下是本篇文章正文内容...
    99+
    2023-06-20
  • C语言实现简易版扫雷游戏
    本文实例为大家分享了C语言实现扫雷游戏的具体代码,供大家参考,具体内容如下 这个小项目源自两个月前学数组的时候,由于觉得比较重要,想记录一下。 首先,大概的思路是要做出两个二维数组充...
    99+
    2022-11-12
  • C语言实现简易的扫雷游戏
    本文实例为大家分享了C语言实现简易的扫雷游戏的具体代码,供大家参考,具体内容如下 在正式讲内容之前先说一说扫雷游戏的规则 游戏规则很简单,点击方格,如果是地雷,游戏失败,找到所有地...
    99+
    2022-11-12
  • C语言简易实现扫雷小游戏
    本文实例为大家分享了C语言实现扫雷小游戏的具体代码,供大家参考,具体内容如下 经典扫雷游戏规则: 当玩家点击游戏区域,该处周围的八个位置有几个雷(如果是角落则是周边三个位置雷的个数,...
    99+
    2022-11-12
  • C语言代码实现简单的扫雷小游戏
    C语言+EASYX实现扫雷,供大家参考,具体内容如下 主要思路就是通过一个二维数组存储不同的数来代表0到8等具体的图片,再配合鼠标的位置和点击情况,来改变数组某一项的值,而显示不同的...
    99+
    2022-11-11
  • 基于C语言实现简单的扫雷小游戏
    本文实例为大家分享了C语言实现简单的扫雷小游戏的具体代码,供大家参考,具体内容如下 首先来规划一下扫雷游戏实现的几个步骤: 初始化棋盘:二维数组的遍历及赋值 为了后续代码的简洁方便,...
    99+
    2022-11-12
  • 用C语言实现简单版9*9扫雷小游戏
    目录一.扫雷的规则二.代码实现前的一些问题1.棋盘尺寸=数组尺寸?2.一个数组足矣?三.代码实现0.初步完成头文件1.游戏的入口-菜单2.棋盘的初始化3.展示棋盘4.布置雷5...
    99+
    2022-11-11
  • 用C语言实现扫雷游戏
    用C语言实现扫雷游戏,因为代码会比较多,所以采用多文件的方式,使代码看起来更好。 一.main.c 在主调函数中首先要提供一个给用户选择的界面,在这里我们假定选择1为开始游戏,0为退...
    99+
    2022-11-12
  • C语言实现简易扫雷游戏详解
    本文实例为大家分享了C语言实现简易扫雷游戏的具体代码,供大家参考,具体内容如下 一、想要达到的游戏功能: 大家如果想编写一个游戏,应具备以下的步骤: 1:了解游戏的规则 2:&nbs...
    99+
    2022-11-12
  • C语言实现简易的扫雷小游戏
    这是一个用C语言实现的控制台扫雷小游戏,实现了随机布置炸弹、扫描炸弹、标记炸弹、百分百第一次不被炸死等功能。 编译器:vs2015 功能模块图 源代码 #include<st...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作