扫雷小游戏

简介: 扫雷小游戏

先上运行图片

91eed87d4b179c0b79184aa9a97de266_fdb0ccfa6caa4ceca60613a315947806.png

首先,我们还是分为三大模块


text.c文件                            //测试游戏(放主函数)


game.c文件                        //游戏函数的实现


game.h文件                       //游戏函数的声明


首先是text.c文件

#define _CRT_SECURE_NO_WARNINGS 1
#include "game.h"
void menu()
{
    printf("*************************************\n");
    printf("*************************************\n");
    printf("**********      1.play    ***********\n");
    printf("**********      0.exit    ***********\n");
    printf("*************************************\n");
    printf("*************************************\n");
}
void game()
{
    printf("扫雷游戏开始\n");
    //设计两个数组存放信息
    char mine[ROWS][COLS] = { 0 };
    char show[ROWS][COLS] = { 0 };
    //初始化棋盘
    //mine初始化全部为'0'
    //show初始化为全‘*’
    init_board(mine, ROWS,COLS,'0');
    init_board(show, ROWS, COLS, '*');
    //打印棋盘
    //display_board(mine, ROW, COL);
    display_board(show, ROW, COL);
    //布置雷
    set_mine(mine, ROW, COL);
    //display_board(mine, ROW, COL);
    //排雷
    FindMine(mine, show, ROW, COL);
    //display_board(show, ROW, COL);
}
int main()
{
    int input = 0;
    srand((unsigned int)time(NULL));
    do
    {
        menu();
        printf("请选择;>\n");
        scanf("%d", &input);
        switch (input)
        {
        case 1:
                game();
                break;
        case 0:
            printf("退出游戏\n");
            break;
        default:
            printf("输入错误,请重新输入\n");
            break;
        }
    } while(input);
    return 0;
}

game.c文件

#define _CRT_SECURE_NO_WARNINGS 1
#include"game.h"
//初始化
void init_board(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;
        }
    }
}
void display_board(char board[ROWS][COLS], int row, int col)
{
    int i = 0;
    int j = 0;
    //列号
    for (j = 0; j <= col; j++)
    {
        printf("%d ", j);
    }printf("\n");
    for (i = 1; i <= row; i++)
    {
        printf("%d ", i);
        for (j = 1; j <= col; j++)
        {
            printf("%c ", board[i][j]);
        }
        printf("\n");
    }
}
void set_mine(char mine[ROWS][COLS], int row, int col)
{
    //布置十个雷
    int count = EASY_COUNT;
    while (count)
    {
        int x = rand() % row + 1;
        int y = rand() % col + 1;
        if (mine[x][y] == '0')
        {
            mine[x][y] = '1';
            count--;
        }
    }
}
int get_mine_count(char mine[ROWS][COLS],int x, int y)
{
    return (mine[x - 1][y] +
        mine[x - 1][y - 1] +
        mine[x][y - 1] +
        mine[x + 1][y - 1] +
        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 (show[x][y] == '*')
            {
                if (mine[x][y] == '1')
                {
                    printf("很遗憾,你被炸死了\n");
                    display_board(mine, ROW, COL);
                    break;
                }
                else
                {
                    int count = get_mine_count(mine, x, y);
                    show[x][y] = count + '0';
                    display_board(show, ROW, COL);
                    win++;
                }
            }
            else
            {
                printf("该坐标已经被排查过了\n");
            }
        }
        else
        { 
            printf("坐标非法,请重新输入\n");
        }
    }
    if (win == EASY_COUNT)
    {
        printf("恭喜你,你赢了\n");
        display_board(mine, ROW, COL);
    }

最后是game.h文件

#pragma once
#include <stdio.h>
#include<stdlib.h>
#include <time.h>
#define ROW 9
#define COL 9
#define ROWS ROW+2
#define COLS COL+2
#define EASY_COUNT 10
//初始化棋盘
void init_board(char board[ROWS][COLS], int rows, int cols,char set);
//打印棋盘
void display_board(char board[ROWS][COLS], int row, int col);
//布置雷
void set_mine(char mine[ROWS][COLS], int row, int col);
//排查雷
void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);
相关文章
|
9月前
|
机器学习/深度学习 人工智能 缓存
探秘 DeepSeek:那些你必须了解的事
DeepSeek是一家由中国幻方量化支持的创新型AI公司,专注于开发高性能、低成本的大语言模型。其独特的技术路径打破了参数规模、能耗成本和认知可靠性之间的“三元悖论”,实现了在单张显卡上运行170亿参数模型的突破。DeepSeek通过开源策略和高性价比模型(如DeepSeek-R1),大幅降低了AI应用门槛,推动了全球开发者社区的发展。其应用场景广泛覆盖教育、医疗、金融等领域,显著提升了工作效率和服务质量。DeepSeek的成功不仅在于技术创新,更在于其开放合作的理念,正引领AI行业的新变革。
1444 9
探秘 DeepSeek:那些你必须了解的事
|
8月前
|
Web App开发 前端开发 数据可视化
20K star!让网页设计秒变手绘风,这个开源库太有创意了!
嗨,大家好,我是小华同学。Rough.js 是一个仅8KB的轻量级图形库,能为网页元素赋予自然的手绘质感,支持手绘风格渲染、全类型图形和跨平台兼容。它适合数据可视化、教育课件、原型设计等场景,具有设计友好、性能卓越、扩展性强等优势。
320 12
|
8月前
|
弹性计算 人工智能 运维
阿里云操作系统控制台实战评测:提升云资源管理与监控效率
阿里云操作系统控制台是一款集成了可视化管理、问题分析和智能助手等功能的运维工具,适用于企业和个人用户。它通过统一界面监控和优化系统运行,结合AI与自动化技术,提升操作系统的使用效率和稳定性。用户无需专业运维知识即可完成系统维护和故障诊断。主要功能包括进程热度追踪、系统诊断等,提供直观的数据展示和详细的分析报告,帮助用户快速定位并解决问题。建议进一步完善操作文档和优化数据可视化效果,以提升用户体验。
219 0
|
监控 API 开发者
深入理解微服务架构:设计与实施
【10月更文挑战第7天】深入理解微服务架构:设计与实施
268 0
|
Ubuntu 数据安全/隐私保护
蓝易云 - ubuntu设置系统代理
以上就是在Ubuntu系统中设置系统代理的步骤,希望对你有所帮助。
450 0
|
移动开发 监控 Android开发
几个系统级崩溃问题和h5加载页面崩溃问题及解决方案
几个系统级崩溃问题和h5加载页面崩溃问题及解决方案
339 0
|
XML 编解码 C#
.NET MAUI 安卓 UI 资源设置
本文主要介绍使用 MAUI 开发安卓应用时,如何更换和处理 UI 资源:应用名称,图标,主题配色,状态栏,闪屏。
878 0
.NET MAUI 安卓 UI 资源设置
|
缓存 Java 关系型数据库
强引用、软引用、弱引用、幻象引用有什么区别和使用场景
强引用、软引用、弱引用、幻象引用有什么区别和使用场景
392 1
|
JavaScript 前端开发 编译器
Vue3 script setup 语法糖,就问你甜不甜
Vue3 script setup 语法糖,就问你甜不甜
1206 2