返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言递归应用实现扫雷游戏
  • 893
分享到

C语言递归应用实现扫雷游戏

2024-04-02 19:04:59 893人浏览 独家记忆
摘要

本文实例为大家分享了C语言递归应用实现扫雷游戏的具体代码,供大家参考,具体内容如下 游戏设计规则: 菜单  两个棋盘,Mine一个布置雷,Show一个给玩家看,玩

本文实例为大家分享了C语言递归应用实现扫雷游戏的具体代码,供大家参考,具体内容如下

游戏设计规则:

  • 菜单  
  • 两个棋盘,Mine一个布置雷,Show一个给玩家看,玩家选择show里的坐标翻开雷阵,在mine里的相同坐标如果是雷则玩家失败游戏结束,若不是雷则判断此坐标周围8个坐标是否有雷,有雷则显示周围总雷数,没有就显示为空格。为了避免判断雷阵最外边一圈坐标时出现溢出,因此设置雷阵数组时行(列)比打印出的要多两行(列),布置雷时也不在最外面一圈布雷。
  • 第一步如果踩雷则将mine中所选坐标位置换为安全,并重新布置雷位,确保玩家第一次不会踩雷。
  • 雷区没有雷时的展开操作:当所以选位置周围8个坐标均无雷时,则分别判断坐标周围8个坐标的周围8个坐标是否有雷(没写错,请仔细思考理解。。),有雷则在该座标处显示雷数,并不再进行下一坐标的判断,若没有则显示空格,并继续进行下一次判断。

函数模块及讲解

test.c文件主要内容及功能讲解

#include"game.h"

int main()
{
      srand((unsigned int)time(NULL));   
      int x = 0;
       
      while (1)      
      {
      menu();//菜单
      printf("请选择:>");
      scanf("%d", &x);
      if (x == 1)
      {
          char mine[ROWS][COLS] = { 0 };//布置雷的棋盘
          char show[ROWS][COLS] = { 0 };//查找雷的棋盘
          //初始化
          setboard(mine, ROWS, COLS, '0');//设置雷的棋盘初始化
          setboard(show, ROWS, COLS, '*');//设置排查的棋盘初始化
          //打印
          displayboard(show, ROW, COL);//打印排查的棋盘9  
          //布雷
          putmine(mine, ROW, COL);//  
             //displayboard(mine, ROW, COL);//打印用来方便测试
           //排雷
          findmine(mine,show, ROW, COL);
      }
      else if (x == 0)
      {
           printf("退出游戏!\n");
           break;
      }
      else
      {
           printf("输入错误,请重新输入!\n");//处理非法输入
      }
      }
 system("pause");
 return 0;
}

game.c文件主要内容及功能讲解

#include"game.h"

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

void setboard(char board[ROWS][COLS], int rows, int cols, char n)//初始化,mine初始化为0,show初始化为*
{
 int x = 0;
 int y = 0;
 int a = 0;
 for (x = 0; x < rows; x++)
 {
  for (y = 0; y < cols; y++)
  {
   board[x][y] = n;
  }
 }
}

void displayboard(char board[ROWS][COLS], int rows, int cols)//打印棋盘
{
 int x = 0;
 int y = 0;
 for (x = 0; x <= cols; x++)
 {
  printf("%d ", x);//打印列的序号
 }
 printf("\n");
 for (x = 1; x <= rows; x++)
 {
  printf("%d ", x);//打印行的序号
  for (y = 1; y <= cols; y++)
  {
   printf("%c ", board[x][y]);
  }
  printf("\n");
 }
 printf("\n");
}

//布雷,使用rand产生随机值,srand调用在主函数里
void putmine(char mine[ROWS][COLS], int rows, int cols)
{
 int x = 0;
 int y = 0;
 int count = low;
 while (count)
 {
  x = rand() % ROW + 1;
  y = rand() % COL + 1;
  if (mine[x][y] == '0')
  {
   mine[x][y] = '1';
   count--;
  }
 }
}


//计算盘中还有多少个*,
//后面用来和雷数比较判断,
//当*等于雷数时排雷成功
int number(char show[ROWS][COLS])
{
 int count = 0;
 int x = 0;
 int y = 0;
 for (x = 1; x <= ROW; x++)
 {
  for (y = 1; y <= COL; y++)
  {
   if (show[x][y] == '*')
    count++;
  }
 }
 return count;
}


void findmine(char mine[ROWS][COLS], char show[ROWS][COLS], int rows, int cols)
{
 int x = 0;
 int y = 0;
 while (number(show) != low)
 {
  printf("请输入查找坐标:>");
  scanf("%d%d", &x, &y);
  if (x > 0 && x <= rows && y > 0 && y <= cols && show[x][y] != ' ')//注意判断坐标合法性
  {
   if (mine[x][y] == '1')
   {
    if (number(show) == ROW * COL)//第一步踩雷时要替换雷位保证玩家不会first blood
    {
     firstsafe(mine, x, y);
     //displayboard(mine, ROW, COL);//用来打印方便测试雷位有没有被替换
     Goto first;//替换之后继续判断该坐标,转到first
    }
    printf("YOU LOSE!GAME OVER!\n");//当玩家不是第一步踩雷时就输了
    printf("\n");
    displayboard(mine, ROW, COL);//打印雷盘让玩家看到自己踩得是不是雷
    break;
   }
   else
   {
    first:
    recfindmine(mine, show, x, y);//展开程序
    displayboard(show, ROW, COL);
    //displayboard(mine, ROW, COL);//方便测试
   }
  }
  else
  {
   printf("坐标错误,请重新输入!\n");
  }
 }
 if (number(show) == low)//当*等于雷数时排雷成功
 {
  printf("YOU WIN!\n");
  displayboard(mine, ROW, COL);
 }
}

//算一个坐标周围8个有没有雷
//mine盘里放的是字符'0'和'1',
//函数返回是整型值,
//'1'-'0'=1;
int minenum(char mine[ROWS][COLS], 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';
}


//本来写的时候写的查找周围8个坐标,结果后来发现找周围4个也是一样的
//用递归来进行判断
//目前这个函数还有bug,展开有时候遇到周围有雷的时候不会停,会继续判断
//导致展开不是连续的,就像扫雷开挂了。。但是基本的展开功能还是能够实现的
//希望看出来的大佬给指点一下,谢谢;
void recfindmine(char mine[ROWS][COLS], char show[ROWS][COLS], int x, int y)
{
 int i = minenum(mine, x, y);
 if (show[x][y] == '*' && i == 0)
 {
  show[x][y] = ' ';
  if (show[x - 1][y] == '*' && (x - 1) > 0 && y > 0)//上
  {
   recfindmine(mine, show, x-1, y);
  }
  //if ((x - 1) > 0 && (y - 1) > 0 && show[x - 1][y - 1] == '*')//左上
  //{
  // recfindmine(mine, show, x-1, y-1);
  //}
  //if ((x - 1) > 0 && (y + 1) > 0 && show[x - 1][y + 1] == '*')//右上
  //{
  // recfindmine(mine, show, x-1, y+1);
  //}
  if (show[x + 1][y] == '*' && (x + 1) > 0 && y > 0)//下
  {
   recfindmine(mine, show, x+1, y);
  }
  //if ((x + 1) > 0 && (y - 1) > 0 && show[x + 1][y - 1] == '*')//左下
  //{
  // recfindmine(mine, show, x+1, y-1);
  //}
  //if ((x + 1) > 0 && (y + 1) > 0 && show[x + 1][y + 1] == '*')//右下
  //{
  // recfindmine(mine, show, x+1, y+1);
  //}
  if (show[x][y + 1] == '*' && x > 0 && (y + 1) > 0)//右
  {
   recfindmine(mine, show, x, y+1);
  }
  if (show[x][y - 1] == '*' && x > 0 && (y - 1) > 0)//左
  {
   recfindmine(mine, show, x, y-1);
  }
 }
 else 
 {
  show[x][y] = i + '0';
 }
}

//保证第一步不死,把第一步的雷替换成0,再随机生成一个不是雷的坐标改成雷
void firstsafe(char mine[ROWS][COLS], int x, int y)
{
 mine[x][y] = '0';
 while (1)
 {
  int a = 0;
  int b = 0;
  a = rand() % ROW + 1;
  b = rand() % COL + 1;
  if (mine[a][b] == '0')
  {
   mine[a][b] = '1';
   break;
  }
 }
}

game.h文件主要内容及功能讲解

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

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

void menu();
void setboard(char board[ROWS][COLS], int rows, int cols,char n);
void displayboard(char board[ROWS][COLS], int rows, int cols);
void putmine(char mine[ROWS][COLS], int rows, int cols);
void findmine(char mine[ROWS][COLS], char show[ROWS][COLS], int rows, int cols);
void recfindmine(char mine[ROWS][COLS], char show[ROWS][COLS], int x, int y);
int minenum(char mine[ROWS][COLS], int x,int y);
int number(char show[ROWS][COLS]);
void firstsafe(char mine[ROWS][COLS], int x, int y);

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

--结束END--

本文标题: C语言递归应用实现扫雷游戏

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

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

猜你喜欢
  • C语言递归应用实现扫雷游戏
    本文实例为大家分享了C语言递归应用实现扫雷游戏的具体代码,供大家参考,具体内容如下 游戏设计规则: 菜单  两个棋盘,Mine一个布置雷,Show一个给玩家看,玩...
    99+
    2024-04-02
  • C语言递归实现扫雷游戏
    前言 首先要实现扫雷原理上同三子棋,都是通过一个二维数组来实现游戏主题功能那么这里有几个值得注意的点 1、初级扫雷我们知道是九乘九数组实现,那么在这里我们创建的是11乘11的数组,目...
    99+
    2024-04-02
  • C语言实现递归版扫雷游戏实例
    目录思路清晰的逻辑菜单棋盘布置雷排雷判断输赢text.c实现game.c实现game.h实现递归部分详解总结思路 清晰的逻辑 为方便将其分为三个文件:text.c(测试) game....
    99+
    2024-04-02
  • 怎么使用C语言递归实现扫雷游戏
    这篇文章主要介绍“怎么使用C语言递归实现扫雷游戏”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用C语言递归实现扫雷游戏”文章能帮助大家解决问题。游戏设计规则:菜单  两个棋...
    99+
    2023-07-02
  • C语言实现自定义扫雷游戏(递归版)
    本文实例为大家分享了C语言自定义扫雷游戏的具体代码,供大家参考,具体内容如下 实现过程 对于用C语言实现扫雷游戏得实现,可将游戏过程分为两个板块。 实现游戏关键功能得函数搭建合理得游...
    99+
    2024-04-02
  • c语言实现含递归清场版扫雷游戏
    目录一,设计思路二.实现方式1.菜单的打印2.game函数3.棋盘的初始化与打印 4.雷的放置,雷的个数5.递归实现一片效果 6.排查雷 三.完整代码总结一,设计思路 想必大家都玩过...
    99+
    2024-04-02
  • C语言怎么通过递归实现扫雷游戏
    这篇“C语言怎么通过递归实现扫雷游戏”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C语言怎么通过递归实现扫雷游戏”文章吧。用...
    99+
    2023-06-30
  • C语言 递归实现排雷游戏
    目录前言一、游戏思路二、游戏框架 1.菜单界面1.菜单:2.菜单的选择:3.实际效果:2.游戏主体1.初始化雷盘及展示界面2.布置雷3.排雷3.游戏函数三、游戏运行四、所有代码1.g...
    99+
    2024-04-02
  • c语言怎么实现含递归清场版扫雷游戏
    这篇文章主要介绍“c语言怎么实现含递归清场版扫雷游戏”,在日常操作中,相信很多人在c语言怎么实现含递归清场版扫雷游戏问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”c语言怎么实现含递归清场版扫雷游戏”的疑惑有所...
    99+
    2023-06-25
  • 用C语言实现扫雷游戏
    用C语言实现扫雷游戏,因为代码会比较多,所以采用多文件的方式,使代码看起来更好。 一.main.c 在主调函数中首先要提供一个给用户选择的界面,在这里我们假定选择1为开始游戏,0为退...
    99+
    2024-04-02
  • C语言数组应用实现扫雷游戏
    本文实例为大家分享了C语言数组应用实现扫雷游戏的具体代码,供大家参考,具体内容如下 扫雷游戏(10×10的面板): 1.定义两个12×12的字符型数组;2.s...
    99+
    2024-04-02
  • 用C语言实现扫雷小游戏
    本文实例为大家分享了C语言实现扫雷小游戏的具体代码,供大家参考,具体内容如下 1. 规则 随便点一个格子,会有一块,上面的数字就代表数字周围八个格子会有几个雷,是1他周围就只有1个雷...
    99+
    2024-04-02
  • 利用C语言实现扫雷游戏
    通过一段时间的C语言学习,想必小伙伴们也想跃跃欲试的编写一些小程序,这个扫雷简易游戏,非常适合C语言初学者去实践。 实现扫雷,首先要有两个棋盘,一个棋盘放置着雷的信息,另个用于展示到...
    99+
    2024-04-02
  • 使用C语言实现扫雷游戏
    目录一、游戏介绍二、实现模块三、实现原理四、实现逻辑五、全部代码六、运行结果本文实例为大家分享了C语言实现扫雷游戏的具体代码,供大家参考,具体内容如下 一、游戏介绍 扫雷游戏是在一个...
    99+
    2022-11-13
    C语言 扫雷
  • C语言中如何使用递归实现排雷游戏
    这篇文章主要介绍了C语言中如何使用递归实现排雷游戏,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。前言扫雷,相信各位都不陌生,以前每台电脑上面都会自带这个小游戏。因此,它可以说...
    99+
    2023-06-25
  • 使用C语言实现扫雷小游戏
    本文实例为大家分享了C语言实现扫雷小游戏的具体代码,供大家参考,具体内容如下 游戏规则 在一个9*9的地图上一共有十个雷,翻开所有不是雷的位置 游戏即为胜利, 如果踩到雷,游戏结束 ...
    99+
    2024-04-02
  • 用C语言实现简单扫雷游戏
    前言 本文写的是用C语言实现扫雷,用递归实现周围一圈无雷时,自动继续判断下一圈是否有雷,直到四周有地雷的信息。 最终结果展示 初始游戏界面 四周无地雷继续向外展开,直到出现地雷信息...
    99+
    2024-04-02
  • C语言实现扫雷经典游戏
    C语言实现扫雷游戏,供大家参考,具体内容如下 实现扫雷游戏 与三子棋游戏类似,为了便于后期对于代码的阅读、理解与地图大小和地雷的数量变更,先用#define定义一个标识符表示一个常量...
    99+
    2024-04-02
  • C语言编程实现扫雷游戏
    本文实例为大家分享了C语言实现扫雷游戏的具体代码,供大家参考,具体内容如下 在我们熟知的扫雷中,我们点击小方块,小方块要么出现数字,要么遇到地雷。我打算,使用数组的方式来完成扫雷游戏...
    99+
    2024-04-02
  • C语言数组实现扫雷游戏
    本文实例为大家分享了C语言数组实现扫雷游戏的具体代码,供大家参考,具体内容如下 游戏界面展示: 一开始菜单界面: 选择 0 退出程序: 选择 1 开始游戏: 输入要排查雷的坐标...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作