C语言实现扫雷游戏

简介: C语言实现扫雷游戏

一、编写思路🍋🍋

1、整体框架🔹🔹

对于扫雷游戏,需要实现两个功能:扫雷和退出游戏,这里需要首先需要利用do—while循环和switch语句来实现,先实现程序的整体框架,再逐步地实现具体的功能。

int main()
{
  int option=0;
  do
  {
    menu();
    printf("请输入:");
    scanf("%d",&option);
    switch (option)
    {
    case 1:
      printf("扫雷游戏\n");
      break;
    case 0:
      printf("退出成功!\n");
      break;
    default:
      printf("你的输入有误,请重新输入:");
    }
 
  } while (option);
  return 0;
}

效果演示:

2、初始化函数🔹🔹

在扫雷游戏中,我们需要设计两个二维数组,一个用来存放雷(雷的位置用‘1’表示,非雷用‘0’表示),另一个用来进行扫雷,初始全为‘*’,但是由于在对存放雷的数组进行扫雷时,容易越界,我们就将存放雷的数组的行数和列数各加2来解决。初始化函数利用两层for循环。

void init(char arr[ROW][COL], int row, int col, char ch)
{
  for (int i = 0; i < row; i++)
  {
    for (int j = 0; j < col; j++)
    {
      arr[i][j] = ch;
    }
  }
}

3、打印函数🔹🔹

扫雷过程中,我们同样需要将扫雷的效果展示到屏幕上,利用双层for循环进行打印。

void print(char arr[ROW][COL], int row, int col)
{
  for (int i = 0; i <= COL; i++)
  {
    printf("%d ", i);
  }
  printf("\n");
  for (int i =0; i < row; i++)
  {
    printf("%d ", i + 1);
    for (int j = 0; j < col; j++)
    {
      printf("%c ", arr[i][j]);
    }
    printf("\n");
  }
}

效果演示:

4、设置雷函数 🔹🔹

我们需要在存放雷的数组中随机生成n个雷,将对应坐标的元素设为‘1’。

void set_bomb(char arr[ROW][COL], int row, int col)
{
  srand((unsigned)time(NULL));
  int count = BOMB;
  while (count)
  {
    int x = rand() % row+1;
    int y = rand() % col + 1;
    if (arr[x][y] == '0')
    {
      arr[x][y] = '1';
      count--;
    }
 
  }
}


效果演示:

5、统计雷函数🔹🔹

统计需要由用户指定一个坐标,然后程序在存放雷的数组中统计其周围的8个坐标中元素为‘1’的个数。

void cout_bomb(char arr[ROW][COL], int x, int y)
{
  return (arr[x - 1][y] +
    arr[x - 1][y - 1] +
    arr[x][y - 1] +
    arr[x + 1][y - 1] +
    arr[x + 1][y] +
    arr[x + 1][y + 1] +
    arr[x][y + 1] +
    arr[x - 1][y + 1] - 8 * '0');
}

6、扫雷函数🔹🔹

扫雷函数利用用户指定的坐标,如果该坐标不是雷,则计算周围雷的个数存放到扫雷数组中,直到排查出所有非雷的坐标为成功,游戏结束,否则“炸死”,游戏结束。

void minesweeper(char mine[ROW][COL], char show[ROW][COL], int row, int col)
{
  int x = 0, y = 0;
  int win = 0;
  while (win < ROW * COL - BOMB)
  {
  printf("请输入要排查雷的坐标:");
    scanf("%d%d", &x, &y);
    if (x< row &&x>=1&& y < col&&y>=1)
    {
      if (show[x][y] == '*')
          {
            if (mine[x][y] == '0')
            {
              show[x][y] = cout_bomb(mine, x, y)+'0';
              win++;
              print(show, ROW, COL);
            }
            else
            {
              printf("您已炸死,游戏结束\n");
              print(mine, row, col);
              break;
            }
          }
          else
          {
            printf("该位置已经排查过\n");
          }
    }
    else
    {
      printf("输入坐标不合法\n");
    }
    
  }
  if (win == ROW * COL - BOMB)
  {
    printf("排雷成功,游戏结束!\n");
  }
 
}

效果演示:

二、整体代码 🍋🍋

1、game.h🔹🔹

#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#define ROW 9
#define COL 9
#define ROWS 9+2
#define COLS 9+2
#define BOMB 10
void menu();
void init(char arr[ROW][COL], int row, int col, char ch);
void print(char arr[ROW][COL], int row, int col);
void set_bomb(char arr[ROW][COL], int row, int col);
int cout_bomb(char arr1[ROW][COL], char arr2[ROW][COL], int row, int col);
void minesweeper(char mine[ROW][COL], char show[ROW][COL], int row, int col);

2、game.c🔹🔹

#define _CRT_SECURE_NO_WARNINGS 1
#include "game.h"
void menu()
{
  printf("*********************************************\n");
  printf("*******          1.开始扫雷       ***********\n");
  printf("*******          0.退出游戏       ***********\n");
  printf("*********************************************\n");
}
void init(char arr[ROW][COL], int row, int col, char ch)
{
  for (int i = 0; i < row; i++)
  {
    for (int j = 0; j < col; j++)
    {
      arr[i][j] = ch;
    }
  }
}
void print(char arr[ROW][COL], int row, int col)
{
  for (int i = 0; i <= COL; i++)
  {
    printf("%d ", i);
  }
  printf("\n");
  for (int i =1; i <= row; i++)
  {
    printf("%d ", i );
    for (int j =1; j <= col; j++)
    {
      printf("%c ", arr[i][j]);
    }
    printf("\n");
  }
}
void set_bomb(char arr[ROW][COL], int row, int col)
{
  srand((unsigned)time(NULL));
  int count = BOMB;
  while (count)
  {
    int x = rand() % row+1;
    int y = rand() % col + 1;
    if (arr[x][y] == '0')
    {
      arr[x][y] = '1';
      count--;
    }
 
  }
}
int cout_bomb(char arr[ROW][COL], int x, int y)
{
  return (arr[x - 1][y] +
    arr[x - 1][y - 1] +
    arr[x][y - 1] +
    arr[x + 1][y - 1] +
    arr[x + 1][y] +
    arr[x + 1][y + 1] +
    arr[x][y + 1] +
    arr[x - 1][y + 1] - 8 * '0');
}
void minesweeper(char mine[ROW][COL], char show[ROW][COL], int row, int col)
{
  int x = 0, y = 0;
  int win = 0;
  while (win < ROW * COL - BOMB)
  {
  printf("请输入要排查雷的坐标:");
    scanf("%d%d", &x, &y);
    if (x< row &&x>=1&& y < col&&y>=1)
    {
      if (show[x][y] == '*')
          {
            if (mine[x][y] == '0')
            {
              show[x][y] = cout_bomb(mine, x, y)+'0';
              win++;
              print(show, ROW, COL);
            }
            else
            {
              printf("您已炸死,游戏结束\n");
              print(mine, row, col);
              break;
            }
          }
          else
          {
            printf("该位置已经排查过\n");
          }
    }
    else
    {
      printf("输入坐标不合法\n");
    }
    
  }
  if (win == ROW * COL - BOMB)
  {
    printf("排雷成功,游戏结束!\n");
  }
 
}

3、test.c🔹🔹

#define _CRT_SECURE_NO_WARNINGS 1
#include "game.h"
void game()
{
  char mine[ROWS][COLS] = { 0 };
  char show[ROWS][COLS] = { 0 };
  init(mine, ROWS, COLS, '0');
  init(show, ROWS, COLS, '*');
  set_bomb(mine, ROW, COL);
  //print(mine, ROW, COL);
  print(show, ROW, COL);
  minesweeper(mine, show, ROW, COL);
}
int main()
{
  int option=0;
  do
  {
    menu();
    printf("请输入:");
    scanf("%d",&option);
    switch (option)
    {
    case 1:
      game();
      break;
    case 0:
      printf("退出成功!\n");
      break;
    default:
      printf("你的输入有误,请重新输入:");
    }
 
  } while (option);
  return 0;
}




目录
相关文章
|
26天前
|
机器学习/深度学习 C语言
九/十:《初学C语言》— 扫雷游戏实现和函数递归基础
【8月更文挑战第5天】本篇文章用C语言采用多文件编写实现了一个基础的扫雷游戏(附源码),并讲解了关于函数递归的基础概念及其相对应的习题练习(附源码)
32 1
九/十:《初学C语言》— 扫雷游戏实现和函数递归基础
|
2月前
|
存储 C语言 开发者
C语言实战 | Flappy Bird游戏
【7月更文挑战第4天】Flappy Bird是由越南开发者制作的简单却极具挑战性的游戏,玩家需控制小鸟穿越水管障碍。游戏涉及角色初始化、显示和更新。小鸟和水管结构体存储数据,使用变量和数组。初始化小鸟和水管,显示背景、小鸟和水管,更新小鸟位置及碰撞检测。代码示例展示了小鸟和水管的状态管理,当小鸟与管道碰撞或触地时,游戏结束。游戏的成功在于其独特的虐心体验。
44 0
C语言实战 | Flappy Bird游戏
|
12天前
|
算法 编译器 C语言
【C语言篇】猜数字游戏(赋源码)
rand函数会返回⼀个伪随机数,这个随机数的范围是在0~RAND_MAX之间,这个RAND_MAX的⼤⼩是依赖编译器上实现的,但是⼤部分编译器上是32767。
|
23天前
|
C语言
扫雷(C语言)
扫雷(C语言)
25 4
|
2月前
|
存储 编译器 C语言
|
2月前
|
存储 编译器 C语言
C语言实战 | “贪吃蛇”游戏
【7月更文挑战第5天】在C语言实战中,本文档介绍了如何构建一个简单的“贪吃蛇”游戏。游戏的核心是控制蛇移动并增长,当吃掉食物时,蛇的身体变长。数据结构使用固定大小的数组表示蛇的位置,变量存储食物位置和蛇的长度。初始化后,利用非阻塞式`getKey()`函数实现WASD键盘控制蛇的运动方向。虽然蛇的边界检测和吃食物后的增长尚未详细说明,但提到了这些问题作为练习留给读者解决,并预告将在后续章节讨论模块化编程以简化复杂代码。
70 0
C语言实战 | “贪吃蛇”游戏
|
2月前
|
存储 数据管理 C语言
C语言实战 | 使用链表完成“贪吃蛇”游戏
【7月更文挑战第1天】整体思维,即系统思维,强调以整体视角理解事物。在编程中,结构体体现这种思想,将相关变量打包处理。示例展示了如何用链表而非数组实现“贪吃蛇”游戏,链表提供了更灵活的动态数据管理。一系列代码图片详细描绘了链表结构体在游戏中的应用,包括节点定义、移动、碰撞检测等,凸显了使用链表的优势和代码的清晰组织。
30 0
C语言实战 | 使用链表完成“贪吃蛇”游戏
|
3月前
|
存储 C语言
C语言实战 | “贪吃蛇”游戏重构
在程序设计中,模块化思维至关重要,尤其对于复杂项目,它帮助分解任务,便于团队协作。以“贪吃蛇”游戏为例,游戏涉及两个角色:蛇和食物。使用数组存储蛇的位置,变量存储食物位置。游戏流程分为初始化、显示和更新数据。初始化时,食物位置随机,蛇的位置根据数组设定。显示数据则根据这些信息在屏幕上呈现角色。更新数据时,处理蛇的移动和增长以及食物的生成和消失。类似地,通过模块化方法可开发“打砖块”游戏,涉及球、球拍和砖墙,每个角色都有相应数据结构和更新逻辑。通过这种方式,游戏开发就像搭建积木,遵循框架逐步实现。
43 0
C语言实战 | “贪吃蛇”游戏重构
|
3月前
|
C语言
【海贼王编程冒险 - C语言海上篇】怎样用C语言实现简单的扫雷游戏?
【海贼王编程冒险 - C语言海上篇】怎样用C语言实现简单的扫雷游戏?
18 1
|
3月前
|
C语言
【海贼王编程冒险 - C语言海上篇】C语言如何实现简单的三子棋游戏?
【海贼王编程冒险 - C语言海上篇】C语言如何实现简单的三子棋游戏?
20 1