扫雷游戏的实现

简介: 扫雷游戏的实现


  1. 扫雷游戏的功能说明

使⽤控制台实现经典的扫雷游戏

• 游戏可以通过菜单实现继续玩或者退出游戏

• 扫雷的棋盘是9*9的格⼦

• 默认随机布置10个雷

• 可以排查雷

◦ 如果位置不是雷,就显⽰周围有⼏个雷

◦ 如果位置是雷,就炸死游戏结束

◦ 把除10个雷之外的所有雷都找出来,排雷成功,游戏结束

 首先,布置雷和排查出的雷都要存储,前面一个是方便代码实现,后面一个是给游戏玩家看到的。如果需要9*9棋盘格,我们需要11*11来存储,为什么呢?原因就是我们需要统计周围雷的时候,如右,方便计算。

  其中,我们给一个棋盘格(mine)存放布置好的雷的信息,另外一个,用数组(show)来存放排查出雷的个数的信息。把雷放在mine中,排查的信息放在show中。mine数组初始化为‘0’,布置雷为‘1’,show初始化为‘*’。

char mine[11][11];

char show[11]1[[11];

同时,设计三个文件

1.test.c

2.game.c

3.game.h

首先test.c

#define _CRT_SECURE_NO_WARNINGS
#include"game.h"
void menu()
{
  printf("***********************\n");
  printf("***** 1. play *****\n");
  printf("***** 0. exit *****\n");
  printf("***********************\n");
}
void game()
{
  char mine[ROWS][COLS];//布置的雷
  char show[ROWS][COLS];//存放排查的雷
  //初始化棋盘格
  Initboard(mine, ROWS, COLS, '0');
  Initboard(show, ROWS, COLS, '*');
  //打印棋盘格
  Displayboard(show, ROW, COL);
  //布置雷
  Setmine(mine, ROW, COL);
  //排查雷
  Findmine(mine, show, ROW, COL);
}
int main()
{
  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("选择错误");
      break;
    }
  } while (input);
  return 0;
}

game.c

#define _CRT_SECURE_NO_WARNINGS
#include"game.h"
void Initboard(char board[ROWS][COLS], int rows, int cols, char set)
{
  int i = 0;
  for (i = 0; i < rows; i++)
  {
    int j = 0;
    for (j = 0; j < cols; j++)
    {
      board[i][j]=set;
    }
  }
}
void Displayboard(char board[ROWS][COLS], int row, int col)
{
  int i = 0;
  printf("--------扫雷游戏-------\n");
  for (i = 0; i <= row; i++)
  {
    printf("%d", i);
  }
  printf("\n");
  for (i = 0; i <= row; i++)
  {
    printf("%d", i);
    int j = 0;
    for (j = 0; j <= col; j++)
    {
      printf("%c", board[i][j]);
    }
    printf("\n");
  }
 
}
void Setmine(char board[ROWS][COLS], int row, int col)
{
  //布置10个雷
  int count = EASY_COUNT;
  while (count)
  {
    int x = rand() % row + 1;
    int y = rand() % col + 1;
    if (board[x][y] == '0')
    {
      board[x][y] = '1';
      count--;
  }
}
int Getminecount(char mine[ROWS][COLS], int x, int y)
   {
  return (mine[x - 1][y]++mine[x][y - 1] + mine[x + 1][y - 1] + mine[x - 1][y] + mine[x + 1][y] + mine[x + 1][y + 1] + mine[x][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
        {
          //该位置不是雷,就统计这个坐标周围有⼏个雷
          int count = Getminecount(mine, x, y);
          show[x][y] = count + '0';
          Displayboard(show, ROW, COL);
          win++;
        }
      }
      else
      {
        printf("坐标⾮法,重新输⼊\n");
      }
    }
    if (win == row * col - EASY_COUNT)
    {
      printf("恭喜你,排雷成功\n");
      Displayboard(mine, ROW, COL);
    }
  }

game.h

 

 

#define _CRT_SECURE_NO_WARNINGS
#pragma once
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define EASY_COUNT 10
#define ROW 9
#define COL 9
#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 board[ROWS][COLS], int row, int col);
//排查雷
void Findmine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);
 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 


相关文章
|
2月前
|
机器学习/深度学习 人工智能 编解码
智谱AI发布新版VLM开源模型GLM-4.1V-9B-Thinking,引入思考范式,性能提升8倍
视觉语言大模型(VLM)已经成为智能系统的关键基石。
740 0
|
4月前
|
机器学习/深度学习 人工智能 负载均衡
Trae 04.22版本深度解析:Agent能力升级与MCP市场对复杂任务执行的革新
在当今快速发展的AI技术领域,Agent系统正成为自动化任务执行和智能交互的核心组件。Trae作为一款先进的AI协作平台,在04.22版本中带来了重大更新,特别是在Agent能力升级和MCP市场支持方面。本文将深入探讨这些更新如何重新定义复杂任务的执行方式,为开发者提供更强大的工具和更灵活的解决方案。
482 1
|
8月前
|
人工智能 搜索推荐 定位技术
AddressCLIP:一张照片就能准确定位!中科院联合阿里云推出街道级图像地理定位模型
AddressCLIP 是由中科院和阿里云联合开发的端到端图像地理定位模型,通过图像-文本对齐和地理匹配技术,实现街道级精度的定位,适用于城市管理、社交媒体、旅游导航等场景。
1131 30
AddressCLIP:一张照片就能准确定位!中科院联合阿里云推出街道级图像地理定位模型
|
9月前
|
存储 自然语言处理 机器人
基于的Qwen模型的智能客服Discord机器人,使用🐫 CAMEL、SambaNova、Firecrawl和Qdrant实现RAG Agent
基于Qwen模型的智能客服Discord机器人,使用CAMEL、SambaNova、Firecrawl和Qdrant实现RAG Agent。构建了一个能够处理复杂问题并能进行快速响应的强大聊天机器人。该机器人可在Discord平台上运行,支持实时对话和语义搜索,提供准确、全面的回答。项目包含详细的安装步骤、代码示例及集成指南,适合开发者快速上手。
|
10月前
|
机器学习/深度学习 算法 计算机视觉
脊椎侧弯检测与智能诊断技术的应用探索
脊椎侧弯是一种常见的骨科疾病,表现为脊柱异常弯曲,可能引发背部疼痛、呼吸困难等问题。本文探讨了利用深度学习、图像处理技术实现脊椎侧弯自动诊断的方法,包括图像预处理、目标检测、弯曲角度计算及模型评估与优化,旨在提高早期诊断的准确性和效率,为医生提供辅助决策支持。
|
消息中间件 传感器 NoSQL
Flink流处理API大合集:掌握所有flink流处理技术,看这一篇就够了
一个flink应用程序开发的步骤大致为五个步骤:构建执行环境、获取数据源、操作数据源、输出到外部系统、触发程序执行。
Flink流处理API大合集:掌握所有flink流处理技术,看这一篇就够了
|
Android开发
Android 配置蓝牙遥控器键值
本文详细介绍了Android系统中配置蓝牙遥控器键值的步骤,包括查看设备号、配置键位映射文件(kl文件)、部署kl文件以及调试过程,确保蓝牙遥控器的按键能正确映射到Android系统对应的按键功能。
1946 1
|
11月前
|
Kubernetes 架构师 Java
史上最全对照表:大厂P6/P7/P8 职业技能 薪资水平 成长路线
40岁老架构师尼恩,专注于帮助读者提升技术能力和职业发展。其读者群中,多位成员成功获得知名互联网企业的面试机会。尼恩不仅提供系统化的面试准备指导,还特别针对谈薪酬环节给予专业建议,助力求职者在与HR谈判时更加自信。此外,尼恩还分享了阿里巴巴的职级体系,作为行业内广泛认可的标准,帮助读者更好地理解各职级的要求和发展路径。通过尼恩的技术圣经系列PDF,如《尼恩Java面试宝典》等,读者可以进一步提升自身技术实力,应对职场挑战。关注“技术自由圈”公众号,获取更多资源。
|
物联网 Java 数据安全/隐私保护
App Inventor 2 低功耗蓝牙(BLE) 硬件接入、数据通信及IO控制
低功耗蓝牙(BLE)以低功耗、低成本、开发简便逐渐被广泛应用,本文主要介绍一款较为通用、价格低廉的BLE设备从零开始如何利用App Inventor 2开发一款自己专属的手机蓝牙App应用。 本文主要通过一款常见的BLE硬件接入控制,介绍硬件接入App Inventor 2 的通用方法,类似的硬件接入都是大同小异的。
611 1
|
API 异构计算
SurfaceView 和 TextureView
SurfaceView 和 TextureView
591 0