利用C语言实现扫雷小游戏

 更新时间:2021年02月23日 14:26:33   作者:yuelinghou  
这篇文章主要为大家详细介绍了利用C语言实现扫雷小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

说明:该游戏的实现需要建立三个文件

  • test2.c:整个游戏,开始游戏/退出游戏的大体执行流程
  • game2.c:具体实现扫雷游戏功能的函数定义
  • game.h:宏定义,函数声明,引用相关C库函数的头文件

test2.c

游戏的大体执行流程

#include"game2.h"

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

//游戏函数
void game()
{
 //雷的信息储存
 //1.雷分布的棋盘
 char mine[ROWS][COLS] = { 0 };//玩家不能看
 //2.排查雷信息的棋盘
 char show[ROWS][COLS] = { 0 };//玩家进行游戏时候的棋盘

 //初始化棋盘
 InitBoard(mine, ROWS, COLS, '0');
 InitBoard(show, ROWS, COLS, '*');

 //打印棋盘
 DisplayBoard(show, ROW, COL);
 //布置雷
 SetMine(mine, ROW, COL);

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

int main()
{
 srand((unsigned int)time(NULL));//设置随机数的生成起点
 int input = 0;
 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;
}

game2.c

具体实现扫雷游戏功能的函数定义

#include"game2.h"

//对mine棋盘,一开始全初始化为'0',后面放雷的坐标位置改为'1'
//对show棋盘,一开始全初始化为'*',后面扫雷时玩家选择的坐标位置改为周围雷的个数
void InitBoard(char(*p)[COLS], int row, int col, char set)//set为需要初始化的字符
{
 int i = 0;
 int j = 0;
 for (i = 0; i < row; i++)
 {
 for (j = 0; j < col; j++)
 {
 *(*(p + i) + j) = set;
 }
 }
}

void DisplayBoard(char(*ps)[COLS], int row, int col)
{
 int i = 0;
 int j = 0;
 //打印最上面一行的数字坐标和分隔行
 printf(" ");
 for (i = 1; i <= 9; i++)
 {
 printf("%d ", i);
 }
 printf("\n");
 printf(" ");
 for (i = 1; i <= 9; i++)
 {
 printf("--");
 }
 printf("\n");
 //打印最左边的数字坐标和分隔行以及相应的棋盘内容
 for (i = 1; i <= row; i++)
 {
 printf("%d |", i);
 for (j = 1; j <= col; j++)
 {
 printf("%c ", *(*(ps + i) + j));
 }
 printf("\n");
 }
}

void SetMine(char(*pm)[COLS], int row, int col)
{
 int count = MAX_MINE;//count记录需要放的雷的个数
 while (count)
 {
 int x = rand() % row + 1;//1-9的数字
 int y = rand() % col + 1;//1-9的数字
 //判断随机生成坐标是已经放雷
 if (*(*(pm + x) + y) == '0')
 {
 *(*(pm + x) + y) = '1';
 count--;
 }
 }
}

//把坐标周围8个位置的字符相加再减去8 * '0',ASCLL编码的差值就是周围雷的个数
static int Find_Mine_Count(char(*pm)[COLS], int x, int y)
{
 return
 (*(*(pm+x + 1) - 1+y) +
 *(*(pm+x + 1)+y) +
 *(*(pm+x + 1) + 1+y) +
 *(*(pm+x)- 1+y) +
 *(*(pm+x)+1+y) +
 *(*(pm+x - 1) - 1+y) +
 *(*(pm+x - 1)+y) +
 *(*(pm+x - 1) + 1+y)) - 8 * '0';
}

void FindMine(char(*pm)[COLS], char(*ps)[COLS], int row, int col)
{
 int x = 0;
 int y = 0;
 int win = 0;
 while (win < row*col - MAX_MINE)//当所有非雷位置都被确认时,win=row*col - MAX_MINE
 {
 printf("请输入坐标(用空格分隔):>");
 scanf("%d%d", &x, &y);
 //1.判断输入坐标是否正确
 if (x >= 1 && x <= row && y >= 1 && y <= col)//坐标正确的情况
 {
 //2.判断输入坐标是否重复
 if (*(*(ps + x) + y) != '*')//坐标重复的情况
 {
 printf("该坐标已被输入\n");
 }
 else//坐标不重复的情况
 {
 //3.判断是否踩雷
 if (*(*(pm + x) + y) == '1')//踩雷的情况
 {
  printf("很遗憾,你被炸死了\n");
  DisplayBoard(pm, row, col);
  break;
 }
 else//没踩雷的情况
 {
  int count = Find_Mine_Count(pm, x, y);
  *(*(ps + x) + y) = count + '0';
  DisplayBoard(ps, row, col);
 }
 }
 }
 else//坐标错误的情况
 {
 printf("输入错误\n");
 }
 }
 //最后判断循环结束是因为踩雷之后break跳出的还是扫雷成功结束循环的
 
 if(win == row * col - MAX_MINE)
 {
 printf("恭喜你,扫雷成功!\n");
 }
}

game2.h

宏定义,函数声明,引用相关C库函数的头文件

//引用库函数的头文件
#include<stdio.h>
#include<stdlib.h>
#include<time.h>

//声明表示棋盘大小的量
#define ROW 9
#define COL 9
#define ROWS 11
#define COLS 11
#define MAX_MINE 10

//声明函数
void InitBoard(char(*p)[COLS], int row, int col, char set);
void DisplayBoard(char(*ps)[COLS], int row, int col);
void SetMine(char(*pm)[COLS], int row, int col);
void FindMine(char(*pm)[COLS], char(*ps)[COLS], int row, int col);

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

相关文章

  • c语言中字符串与字符串数组详解

    c语言中字符串与字符串数组详解

    在C语言当中,字符串数组可以使用char a[] [10]; 或者char *a[]; 表示,下面这篇文章主要给大家介绍了关于c语言中字符串与字符串数组的相关资料,需要的朋友可以参考下
    2021-11-11
  • C++中缀表达式转后缀表达式的方法

    C++中缀表达式转后缀表达式的方法

    这篇文章主要介绍了C++中缀表达式转后缀表达式的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • C++实现数组的排序/插入重新排序/以及逆置操作详解

    C++实现数组的排序/插入重新排序/以及逆置操作详解

    将新的数字与已经排序好的数组中的数字一一比较,直到找到插入点,然后将插入点以后的数字都向后移动一个单位(a[i+1]=a[i]),然后将数据插入即可
    2013-10-10
  • ubuntu 下编译C++代码出现的问题解决

    ubuntu 下编译C++代码出现的问题解决

    这篇文章主要介绍了ubuntu 下编译C++代码出现的问题解决的相关资料,需要的朋友可以参考下
    2015-03-03
  • C++生成格式化的标准字符串实例代码

    C++生成格式化的标准字符串实例代码

    这篇文章主要给大家介绍了关于C++生成格式化的标准字符串的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用C++具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • C语言学习之指针的使用详解

    C语言学习之指针的使用详解

    想突破C语言的学习,对指针的掌握是非常重要的,本文为大家总结了C语言中指针的相关知识点,文中的示例代码讲解详细,感兴趣的小伙伴可以学习一下
    2022-10-10
  • C语言 指针综合解析

    C语言 指针综合解析

    指针可以表示一个变更的地址,在计算机程序中,通常表示内存地址,存储数据的地址,下面这篇文章主要给大家综合的介绍了关于C语言指针的本质与用法
    2021-11-11
  • Qt中互斥锁QMutex和QMutexLocker的使用

    Qt中互斥锁QMutex和QMutexLocker的使用

    本文主要介绍了Qt中互斥锁QMutex和QMutexLocker的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-05-05
  • C/C++中static,const,inline三种关键字详细总结

    C/C++中static,const,inline三种关键字详细总结

    以下是对C/C++中static,const,inline的三种关键字进行了详细的分析介绍,需要的朋友可以过来参考下
    2013-09-09
  • 教你Clion调试ROS包的方法

    教你Clion调试ROS包的方法

    Clion是一款专门开发C以及C++所设计的跨平台的IDE,本文给大家介绍Clion调试ROS包的方法,感兴趣的朋友跟随小编一起看看吧
    2021-07-07

最新评论