基于C语言实现简单的扫雷小游戏

 更新时间:2021年11月22日 09:39:49   作者:504 Gateway Time-out  
这篇文章主要为大家详细介绍了基于C语言实现简单的扫雷小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

首先来规划一下扫雷游戏实现的几个步骤:

初始化棋盘:二维数组的遍历及赋值
为了后续代码的简洁方便,我们用'0'来初始化

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

布置雷的信息:应用随机函数进行赋值

void SetMine(char mine[ROWS][COLS], int row, int col)
{
 int count = EASY_COUNT;
 while (count)
 {
  int x = rand() % row + 1;
  int y = rand() % col + 1;

  if (mine[x][y] == '0')
  {
   mine[x][y] = '1';
   count--;
  }
 }
}

排查雷:

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
   {
    //计算x,y坐标周围有几个雷
    int n=get_mine_count(mine, x, y);
    show[x][y] = n + '0';
    DisplayBoard(show, row, col);
    win++;

   }
   
   
  }
  else
   printf("输入坐标错误,请重新输入\n");

 }
 if (win == row * col - EASY_COUNT)
 {
  printf("恭喜你,排雷成功\n");
  DisplayBoard(mine, row, col);
 }
}

下面是游戏实现的完整代码,依旧是分为了3个版块,为了更好的管理代码,提高代码的可读性和可移植性

game2.h

#include <stdio.h>
#include <time.h>
#include <stdlib.h>
#define ROW 9
#define COL 9
#define  EASY_COUNT 10

#define ROWS ROW+2
#define COLS COL+2

//初始化棋盘
void InitBoard(char board[ROWS][COLS], int rows, int cols, char set);
//打印棋盘
void DisplayBoard(char board[ROWS][COLS], int row, int col);
//布置雷
void SetMine(char mine[ROWS][COLS], int row, int col);
//排查雷
void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);

game2.c

#include "game2.h"

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

 }
}
//布置雷
void SetMine(char mine[ROWS][COLS], int row, int col)
{
 int count = EASY_COUNT;
 while (count)
 {
  int x = rand() % row + 1;
  int y = rand() % col + 1;

  if (mine[x][y] == '0')
  {
   mine[x][y] = '1';
   count--;
  }
 }
}
static int get_mine_count(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] + 
  mine[x + 1][y + 1] +
  mine[x][y + 1] + 
  mine[x - 1][y + 1]+
  mine[x+1][y-1]-8*'0';
}


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
   {
    //计算x,y坐标周围有几个雷
    int n=get_mine_count(mine, x, y);
    show[x][y] = n + '0';
    DisplayBoard(show, row, col);
    win++;

   }
   
   
  }
  else
   printf("输入坐标错误,请重新输入\n");

 }
 if (win == row * col - EASY_COUNT)
 {
  printf("恭喜你,排雷成功\n");
  DisplayBoard(mine, row, col);
 }
}

test.c

#include "game2.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 };//存放排查出的雷的信息

 //初始化mine数组全部为‘0'
 InitBoard(mine, ROWS, COLS, '0');
 //初始化show数组全部为‘0'
 InitBoard(show, ROWS, COLS, '*');

 //打印棋盘
 //DisplayBoard(mine, ROW, COL);

 //布置雷
 SetMine(mine, ROW, COL);
 DisplayBoard(show, ROW, COL);

 //DisplayBoard(mine, ROW, COL);

 //排查雷
 FindMine(mine, show, ROW, COL);
}
void test()
{
 int input = 0;
 srand((unsigned int)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);
}
int main()
{
 test();
 return 0;

}

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

相关文章

  • 解决pip install dlib报错C++11 is required to use dlib

    解决pip install dlib报错C++11 is required to use dlib

    这篇文章主要介绍了在使用pip install dlib安装dlib的时候报错C++11 is required to use dlib的解决方法,需要的的小伙伴可以参考一下,希望对你有所帮助
    2022-02-02
  • 基于Windows API实现遍历所有文件并删除的方法

    基于Windows API实现遍历所有文件并删除的方法

    这篇文章主要介绍了基于Windows API实现遍历所有文件并删除的方法,是win32应用程序的一个比较典型的文件操作应用技巧,需要的朋友可以参考下
    2015-04-04
  • C++ 异常的详细介绍

    C++ 异常的详细介绍

    这篇文章主要介绍了C++ 异常的详细介绍的相关资料,希望通过本文大家能够掌握C++异常的使用方法,需要的朋友可以参考下
    2017-09-09
  • C++基础知识实例解析(一)

    C++基础知识实例解析(一)

    这篇文章主要对C++基础知识实例解析,通过四个简短的案例,巩固大家的基础知识,需要的朋友可以参考下
    2015-08-08
  • centos 7 vscode cmake 编译c++工程的教程详解

    centos 7 vscode cmake 编译c++工程的教程详解

    这篇文章给大家介绍了centos 7 使用vscode+cmake配置简单c++项目的方法,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2020-05-05
  • C++中move的使用及说明

    C++中move的使用及说明

    这篇文章主要介绍了C++中move的使用及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • C语言数组超详细讲解上

    C语言数组超详细讲解上

    数组是一组有序的数据的集合,数组中元素类型相同,由数组名和下标唯一地确定,数组中数据不仅数据类型相同,而且在计算机内存里连续存放,地址编号最低的存储单元存放数组的起始元素,地址编号最高的存储单元存放数组的最后一个元素
    2022-04-04
  • C语言关于include顺序不同导致编译结果不同的问题

    C语言关于include顺序不同导致编译结果不同的问题

    这篇文章主要介绍了在日常调试C语言中include的顺序不同从而影响最后编译结果不同的问题,究其原因是写代码的习惯所导致,下面跟小编一起来看看吧
    2022-04-04
  • C语言之关于二维数组在函数中的调用问题

    C语言之关于二维数组在函数中的调用问题

    这篇文章主要介绍了C语言之关于二维数组在函数中的调用问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • 实例详解C++中指针与引用的区别

    实例详解C++中指针与引用的区别

    引用是C++引入的重要机制(C语言没有引用),它使原来在C中必须用指针来实现的功能有了另一种实现的选择,在书写形式上更为简洁,那么引用的本质是什么,它与指针又有什么关系呢?这篇文章主要给大家介绍了关于C++中指针与引用的区别,需要的朋友可以参考下
    2021-07-07

最新评论