C语言实现扫雷游戏小项目

 更新时间:2021年11月25日 15:33:13   作者:XATU的弟中之弟  
这篇文章主要为大家详细介绍了C语言实现扫雷游戏小项目,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

一.基本实现功能

1.建立一个游戏菜单

2.创建游戏盘,一个埋雷,一个显示。

3.打印游戏盘。

4.翻开坐标如若没踩到雷显示周围一圈8个有几个雷。

5.判断胜利 翻开的格子数等于没埋雷的个数。

二.源代码展示

1.头文件  minesweep.h

#pragma once
#include <stdio.h>
#include <Windows.h>
#include <string.h>
#include <time.h>
#include <stdlib.h>
#define _CRT_SECURE_NO_WARNINGS
#define ROW 12
#define COL 12
#define NUM 10
#define BOOM '1'
void Game();
int Login();

2.游戏逻辑 game.c

#include "minesweep.h"
void Menu() {
 printf("*------------------*\n");
 printf("|    1.开始游戏    |\n");
 printf("|    2.退出游戏    |\n");
 printf("*------------------*\n");
 printf("请输入你的选择:");
}
int main()
{
 int flag = 0;
 int sclect = 0;
 srand((unsigned long)time(NULL));
 Menu();
 while (!flag) {
  scanf_s("%d", &sclect);
  switch (sclect) {
  case 1:
   Game();
   break;
  case 2:
   flag = 1;
   break;
  default:
   printf("你输入的数据不合法,请重新输入!");
   break;
  }
 }
 printf("下次再来玩吧!再见!");
 return 0;
}

3.实现函数 mysweep.c

#include "minesweep.h"
void SetBoom(char board[][COL],int row,int col) {//埋雷
 int i = 0;
 while (i < NUM) {
  int _x = rand() % 10 + 1;                //我们的棋盘是10*10 那就模10+1 xy 对应放雷
  int _y = rand() % 10 + 1;
  if (board[_x][_y] == BOOM) {             //可能随机是重复那就不放了
   continue;
  }
  board[_x][_y] = BOOM;
  i++;
 }
}
 
void Showboard(char board[][COL], int row, int col) {//棋盘的打印
 printf("     ");
 for (int i = 1; i < col - 1; i++)
 {
  printf("%d ", i);
 }
 printf("\n");
 for (int j = 1; j < row - 1; j++)
 {
  printf("%2d  ", j);
  printf("|");
  for (int k = 1; k < col - 1; k++)
  {
   printf("%c|", board[j][k]);
  }
  printf("\n");
 }
 printf("\n");
}
 
int CountSweeps(char board[][COL], int x, int y) {  //我们存的是字符数组哦 
 return board[x - 1][y - 1] + board[x - 1][y] + \
  board[x - 1][y + 1] + board[x][y - 1] + \
  board[x][y + 1] + board[x + 1][y - 1] + \
  board[x + 1][y] + board[x + 1][y + 1] - 8 * '0';
}
 
void Game() {
 char show_board[ROW][COL];
 char sweep_board[ROW][COL];
 int clear = 0;
 int sum = (ROW - 2) * (COL - 2) - NUM;
 memset(show_board, '*', sizeof(show_board));
 memset(sweep_board, '0', sizeof(sweep_board));
 SetBoom(sweep_board, ROW, COL);
 while (1) {
  int x = 0;
  int y = 0;
  system("cls");
  Showboard(show_board,ROW,COL);
  printf("请输入你要翻开的坐标:");
  scanf_s("%d %d", &x, &y);
  if (!(x >= 1 && x <= ROW - 2 && y >= 1 && y <= COL - 2)) {
   printf("你输入的数据不合法!请重新输入!");
  }
  if (show_board[x][y] != '*') {
   printf("扫雷的位置已经被排除!\n");
   continue;
  }
  if (sweep_board[x][y] == '1') {
   printf("对不起,你被炸死了!\n");
   break;
  }
  else {
   int count = CountSweeps(sweep_board,x,y);//翻开没有被炸死而且合法那就根据判断胜利因数咱就空白++
   show_board[x][y] = count + '0';
   clear++;
  }
  if (clear >= sum) {    //++=就是原本设置除雷剩下的刚好相等就胜利
   printf("恭喜你,你赢了!\n");
   break;
  }
 }
}

三.小结

这次的扫雷还是很初阶的没有图形操作界面 而且和我们老xp上面的扫雷不一样很多功能还没有实现比如插旗排雷 还有点开一个·周围还能展开很多格子,还是有待提高希望各路大神前来指证谢谢!!!

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

相关文章

  • QT编写地图实现获取区域边界

    QT编写地图实现获取区域边界

    区域边界是一些坐标点集合,而且不同的行政区划得到的区域边界点数组集合个数不同。本文将具体介绍QT在编写地图时如何实现获取区域边界,需要的可以参考一下
    2022-01-01
  • C语言函数栈帧的创建与销毁原理图解

    C语言函数栈帧的创建与销毁原理图解

    我们知道c语言中函数都是被调用的,main函数里面能调用其他函数,其实main函数也是被别的函数调用的,下面通过本文给大家分享c语言函数栈帧的创建和销毁过程,一起看看吧
    2022-05-05
  • C++ List链表的介绍和使用

    C++ List链表的介绍和使用

    list是可以在常数范围内在任意位置进行插入和删除的序列式容器,并且该容器可以前后双向迭代,这篇文章主要介绍了C++ List链表的介绍和使用,需要的朋友可以参考下
    2023-03-03
  • C++ stack与queue模拟实现详解

    C++ stack与queue模拟实现详解

    这篇文章主要给大家介绍了关于c++stack与queue模拟实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面跟着小编来一起学习学习吧
    2021-08-08
  • C++实现快捷店会员管理系统

    C++实现快捷店会员管理系统

    这篇文章主要为大家详细介绍了C++实现快捷店会员管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • c语言实现通讯录管理系统详细实例

    c语言实现通讯录管理系统详细实例

    这篇文章主要给大家介绍了关于c语言实现通讯录管理系统的相关资料,通讯录管理系统是一种常见的应用程序,可以用来管理联系人的信息,包括姓名、电话号码、地址等,需要的朋友可以参考下
    2023-07-07
  • 解析C++中不能重载为友元函数的四个运算符

    解析C++中不能重载为友元函数的四个运算符

    以下是对C++中不能重载为友元函数的四个运算符进行了详细的分析介绍,需要的朋友可以过来参考下
    2013-07-07
  • C语言实现顺序表的全操作详解

    C语言实现顺序表的全操作详解

    顺序表,全名顺序存储结构,是线性表的一种,线性表用于存储逻辑关系为“一对一”的数据,顺序表自然也不例外,不仅如此,顺序表对数据的物理存储结构也有要求,跟随下文来具体了解吧
    2022-04-04
  • C语言数据结构之队列算法详解

    C语言数据结构之队列算法详解

    这篇文章介绍了C语言数据结构之队列的算法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-12-12
  • 深入理解void以及void指针的含义

    深入理解void以及void指针的含义

    本篇文章对小编void以及void指针的含义进行了详细的分析和介绍。需要的朋友参考下
    2013-05-05

最新评论