扫雷简单版

简介: 关于c语言设计的扫雷小游戏

@TOC

前言

代码解读在代码中

1.test.c

#include"game.h"
void menu()
{
    printf("***********************\n");
    printf("*******1.play 0.exit***\n");
    printf("***********************\n");
}
void game()
{
    char mine[rows][cols] = { 0 };
    char slow[rows][cols] = { 0 };//初始化 多了两行两列 就是为了不越界 
    initboard(mine, row+2, col+2,'0');//假设为9*9的雷盘 变成11*11是为了防止在最边上的坐标寻找周围8个坐标时 越界
    initboard(slow, row+2, col+2, '*');//初始化 我们要看到的雷盘
    displayboard(slow, row, col);//打印雷盘
    setmine(mine, col, row);//布置雷
    findmine(mine,slow, 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;
}

2.game.h

#define _CRT_SECURE_NO_WARNINGS
#define row  9
#define col  9
#define rows row+2
#define cols col+2
#define easycount 10
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
void initboard(char board[rows][cols], int Rows, int Cols);
void displayboard(char board[row][col], int Row, int Col);
void setmine(char mine[row][col], int Row, int Col);
void findmine(char mine[row][col],char  slow[row][col], int Row, int Col);

3.game.c

#include"game.h"
void initboard(char board[rows][cols], int Rows, int Cols,char set)
{
    int i = 0;
    int j = 0;
    for (i = 0; i < Rows; i++)
    {
        for (j = 0; j < Cols; j++)
        {
            board[i][j] = set;// mine雷盘是用来埋雷的 要传过来'0'
        }                     //slow雷盘是用来排查雷的 要传过来'*'  
    }
}
void displayboard(char board[row][col], int Row, int Col)//打印雷盘
{
    int i = 0;
    int j = 0;//实际看到的9*9的雷盘 所以传过来 行 9 列 9
    for (i = 1; i <= Row; i++)
    {
        for (j = 1; j <= Col; j++)
        {
            printf("%c ", board[i][j]);
        }
        printf("\n");
    }
}
void setmine(char mine[row][col], int Row, int Col)//布置雷
{
    int count = 10;//设置雷数为10
    while (count)
    {
        int x = rand() % row + 1;//将x y的坐标设为随机数
        int y = rand() % col + 1;
        if (mine[x][y] == '0')
        {
            mine[x][y] = '1';
            count--;
        }
    }
}
int nofind(char mine[row][col], int x, int y)//查看坐标的周围8个坐标是否有雷
{
    return  (mine[x - 1][y - 1] + mine[x - 1][y] + mine[x - 1][y + 1] +  + mine[x][y - 1] + mine[x][y + 1]
        + mine[x + 1][y] + mine[x + 1][y + 1] + mine[x + 1][y - 1]) - 8 * '0';
}//因为是字符数字 所以需要减去字符0 变成数字
void findmine(char mine[row][col], char slow[row][col],int Row, int Col)//排查雷
{
    int x = 0;
    int y = 0;
    int count = 0;
    int win = 0;
    while (win<row*col-easycount)//雷盘为9*9 -10个雷  若将不是雷的都找到了 则跳出循环
    {
        printf("输入要排查雷的坐标:>");
        scanf("%d%d", &x, &y);
        int s1 = x;
        int s2 = y;
        if(x>=1&&y<=Row&&y>=1&&y<=Col)//雷的范围
        {
            if (mine[x][y] == '1')
            {
                printf("被炸死了\n");
                displayboard(mine, row, col);
                break;
            }
            count = nofind(mine, x, y);
            slow[x][y] = count+'0';//将周围有没有雷的数字传到slow雷盘中
            displayboard(slow, row, col);  //因为里面存放字符  所以要转化到字符
            win++;
        }                        
        else
        {
            printf("坐标非法\n");
        }
    }
    if (win == row * col - easycount)//easycount 为设置雷数
    {
        printf("排雷成功\n");
        displayboard(mine, row, col);//将雷的分布打印
    }
}
目录
相关文章
|
4月前
|
数据处理 开发工具 开发者
requirement.txt 管理python包依赖
在 Python 项目中,`requirements.txt` 用于记录依赖库及其版本,便于环境复现。本文介绍了多种生成该文件的方法:基础方法使用 `pip freeze`,进阶方法使用 `pipreqs`,专业方法使用 `poetry` 或 `pipenv`,以及手动维护方式。每种方法适用不同场景,涵盖从简单导出到复杂依赖管理,并提供常见问题的解决方案,帮助开发者高效生成精准的依赖列表,确保项目环境一致性。
1367 4
|
存储 安全 Java
ConcurrentLinkedQueue详解
通过本文的介绍,希望您能够深入理解 `ConcurrentLinkedQueue`的工作原理、主要特性、常用方法以及实际应用,并在实际开发中灵活运用这些知识,编写出高效、健壮的并发程序。
322 3
|
存储 弹性计算 安全
阿里云服务器ECS实例规格族ecs.xlarge详解
阿里云服务器ECS实例规格族ecs.xlarge详解阿里云服务器ECS分为多种实例规则,常见的有计算型c、通用型g和内存型r等,large代表vCPU核数,re内存增强、se代表存储增强、ne代表网络增强等,阿里云百科分享阿里云服务器ECS实例命名规则及举例说明:
1013 0
阿里云服务器ECS实例规格族ecs.xlarge详解
|
存储 JavaScript 前端开发
基于SpringBoot和微信小程序的餐馆点餐系统的设计和实现(一)
基于SpringBoot和微信小程序的餐馆点餐系统的设计和实现
1334 0
|
算法 计算机视觉
泊松分布采样 (Poisson-Disk-Sample)代码及详细注释【OpenCV】
泊松分布采样 (Poisson-Disk-Sample)代码及详细注释【OpenCV】
1354 0
泊松分布采样 (Poisson-Disk-Sample)代码及详细注释【OpenCV】
|
C# C++
C#调用C/C++ DLL 参数传递和回调函数的总结
原文:C#调用C/C++ DLL 参数传递和回调函数的总结 Int型传入: Dll端: extern "C" __declspec(dllexport) int Add(int a, int b) ...
6131 0
|
9天前
|
数据采集 人工智能 安全

热门文章

最新文章