C语言实现简易扫雷小游戏

 更新时间:2019年10月21日 16:25:42   作者:筱肖  
这篇文章主要为大家详细介绍了C语言实现简易扫雷小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

我们经常在电脑上面玩的扫雷游戏,很考验我们的判断能力,但是实现一个扫雷游戏并不是很困难,只要多注意一些细节就好,就可以将一个简单的扫雷游戏写出来!

接下来先介绍扫雷游戏要实现的功能:

首先,要对雷阵进行初始化,在初始化的时候要注意要定义两个数组,一个是让我们扫雷的阵,另外一个就是显示某一个地方的周围的雷的总个数的矩阵,在初始化的时候要注意为了避免传址的问题,我们把它写在主函数里面。

char mine[rows][cols];
char show[rows][cols];
 int i = 0;
 int j = 0;
 for (i = 0; i < rows - 1; i++)
 {
 for (j = 0; j < cols - 1; j++)
 {
  mine[i][j] = '0';
  show[i][j] = '*';
 }
 }

接下来就是电脑在随机布局雷阵的函数,这个函数要用到rand()&nbsp;函数,来产生随机值,在雷阵里面随机布雷。

void set_mine(char mine[rows][cols])
{
 int count = Count;
 int x = 0;
 int y = 0;
 srand((unsigned)time(NULL));
 while (count)
 {
 x = rand() % 9 + 1;
 y = rand() % 9 + 1;
 if (mine[x][y] == '0')
 {
  mine[x][y] = '1';
  count--;
 }
 }
}

再有就是计算雷的个数的函数,要讲某一个坐标位置的周围8个位置的雷的个数算出来,并且将个数显示出来

int get_num(char mine[rows][cols], int x, int y)
{
 int count = 0;
 if (mine[x - 1][y - 1] == '1')//左上方
 {
 count++;
 }
 if (mine[x - 1][y] == '1')//左边
 {
 count++;
 }
 if (mine[x - 1][y + 1] == '1')//左下方
 {
 count++;
 }
 if (mine[x][y - 1] == '1')//上方
 {
 count++;
 }
 if (mine[x][y + 1] == '1')//下方
 {
 count++;
 }
 if (mine[x + 1][y - 1] == '1')//右上方
 {
 count++;
 }
 if (mine[x + 1][y] == '1')//右方
 {
 count++;
 }
 if (mine[x + 1][y + 1] == '1')//右下方
 {
 count++;
 }
 return count;
}

将扫雷函数的各个函数都实现了之后,我们来看一下完整的代码

头文件game.h 

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<string.h>
#define rows 11
#define cols 11
#define Count 10
 
int menu();//菜单函数
void display(char show[rows][cols]);
int Game(char mine[rows][cols],char show[rows][cols]);//游戏
void set_mine(char mine[rows][cols]);//设置雷的位置
int Sweep(char mine[rows][cols], char show[rows][cols]);//开始扫雷
int get_num(char mine[rows][cols], int x, int y);//计算雷的个数

实现函数 game.c

#include"game.h"
 
//菜单函数
int menu()
{
 printf("********************************************\n");
 printf("********************************************\n");
 printf("*************welcome to saolei*************\n");
 printf("*************  1.   play  *************\n");
 printf("*************  0.   exit  *************\n");
 printf("********************************************\n");
 printf("********************************************\n");
 return 0;
}
 
 
//设置雷的位置
void set_mine(char mine[rows][cols])
{
 int count = Count;
 int x = 0;
 int y = 0;
 srand((unsigned)time(NULL));
 while (count)
 {
 x = rand() % 9 + 1;
 y = rand() % 9 + 1;
 if (mine[x][y] == '0')
 {
  mine[x][y] = '1';
  count--;
 }
 }
}
 
//打印下棋完了显示的界面
void display(char show[rows][cols]) 
{
 int i = 0;
 int j = 0;
 printf(" ");
 for (i = 1; i < cols - 1; i++)
 {
 printf(" %d ", i);
 }
 printf("\n");
 for (i = 1; i < rows - 1; i++)
 {
 printf("%d", i);
 for (j = 1; j < cols - 1; j++)
 {
  printf(" %c ", show[i][j]);
 }
 printf("\n");
 }
}
 
//计算雷的个数
int get_num(char mine[rows][cols], int x, int y)
{
 int count = 0;
 if (mine[x - 1][y - 1] == '1')//左上方
 {
 count++;
 }
 if (mine[x - 1][y] == '1')//左边
 {
 count++;
 }
 if (mine[x - 1][y + 1] == '1')//左下方
 {
 count++;
 }
 if (mine[x][y - 1] == '1')//上方
 {
 count++;
 }
 if (mine[x][y + 1] == '1')//下方
 {
 count++;
 }
 if (mine[x + 1][y - 1] == '1')//右上方
 {
 count++;
 }
 if (mine[x + 1][y] == '1')//右方
 {
 count++;
 }
 if (mine[x + 1][y + 1] == '1')//右下方
 {
 count++;
 }
 return count;
}
//扫雷
int Sweep(char mine[rows][cols], char show[rows][cols])
{
 int count = 0;
 int x = 0;
 int y = 0;
 while (count!=((rows-2)*(cols-2)-Count))
 {
 printf("请输入坐标:\n");
 scanf("%d%d", &x, &y);
 if (mine[x][y] == '1')
 {
  printf("你踩到雷了!\n");
  return 0;
 }
 else
 {
  int ret = get_num(mine, x, y);
  show[x][y] = ret + '0';
  //set_mine(mine);
  display(show);
  count++;
 }
 }
 printf("恭喜你赢了!\n");
 display(mine);
 return 0;
}
 
 
//游戏
int Game(char mine[rows][cols],char show[rows][cols])
{
 set_mine(mine);
 display(show);
 //display(mine);//可以将雷的位置显示出来
 Sweep(mine,show);
 return 0;
}

最后就是测试函数 text.c

#include"game.h"
 
int main()
{
 int input = 0;
 char mine[rows][cols];
 char show[rows][cols];
 int i = 0;
 int j = 0;
 for (i = 0; i < rows - 1; i++)
 {
 for (j = 0; j < cols - 1; j++)
 {
  mine[i][j] = '0';
  show[i][j] = '*';
 }
 }
 menu();
 while (1)
 {
 printf("请选择:");
 scanf("%d", &input);
 if (input == 1)
 {
  printf("进入游戏\n");
  Game(mine,show);
  break;
 }
 else if (input == 0)
 {
  printf("退出游戏!\n");
  exit(0);
  break;
 }
 else
 {
  printf("输入有误!\n");
 }
 }
 return 0;
}

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

相关文章

  • C语言刷题判断链表中是否有环题解

    C语言刷题判断链表中是否有环题解

    这篇文章主要为大家介绍了C语言刷题判断链表中是否有环题解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-07-07
  • OpenCV图像旋转Rotate的详细介绍

    OpenCV图像旋转Rotate的详细介绍

    这篇文章主要介绍了OpenCV图像旋转Rotate,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • 用VC++6.0的控制台实现2048小游戏的程序

    用VC++6.0的控制台实现2048小游戏的程序

    本文是作者拜读刘地同学的《C语言控制台版2048》之后感觉非常不错,添加了注释之后分享给大家的,方便更多的初学者阅读学习,有需要的小伙伴参考下。
    2015-03-03
  • C语言实现简易的三子棋游戏

    C语言实现简易的三子棋游戏

    这篇文章主要为大家详细介绍了C语言实现简易的三子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-12-12
  • C++模板编程特性之移动语义

    C++模板编程特性之移动语义

    首先,移动语义和完美转发这两个概念是在C++的模板编程的基础上,新增的特性,主要是配合模板来使用。本篇会从C++的值类型,到移动拷贝与移动赋值来理解移动语义与完美转发
    2022-08-08
  • C++ 格式化日志输出实现代码

    C++ 格式化日志输出实现代码

    这篇文章主要介绍了C++ 格式化日志输出实现代码,需要的朋友可以参考下
    2019-04-04
  • 详解C/C++ Linux出错处理函数(strerror与perror)的使用

    详解C/C++ Linux出错处理函数(strerror与perror)的使用

    我们知道,系统函数调用不能保证每次都成功,必须进行出错处理,这样一方面可以保证程序逻辑正常,另一方面可以迅速得到故障信息。本文主要为大家介绍两个出错处理函数(strerror、perror)的使用,需要的可以参考一下
    2023-01-01
  • OpenCV reshape函数实现矩阵元素序列化

    OpenCV reshape函数实现矩阵元素序列化

    reshape函数是OpenCV中一个很有用的函数,不仅可以改变矩阵的通道数,还可以对矩阵元素进行序列化。本文将主要介绍如何通过reshape实现矩阵元素序列化,需要的小伙伴可以参考一下
    2021-12-12
  • C语言数据结构进阶之栈和队列的实现

    C语言数据结构进阶之栈和队列的实现

    栈和队列,严格意义上来说,也属于线性表,因为它们也都用于存储逻辑关系为 "一对一" 的数据,但由于它们比较特殊,因此将其单独作为一章,做重点讲解
    2021-11-11
  • c++ std::sort使用自定义的比较函数排序方式

    c++ std::sort使用自定义的比较函数排序方式

    文章介绍了使用std::sort对容器内元素进行排序的基本方法,包括自定义排序函数和在类中调用自定义成员函数进行排序的方法,文章还指出了在传递成员函数指针时可能会遇到的错误,并提供了使用Lambda表达式的解决办法
    2025-02-02

最新评论