c语言——扫雷游戏(简易版)

目录

  • 前言
  • 游戏设计

前言

什么是扫雷游戏?
游戏目标是在最短的时间内根据点击格子出现的数字找出所有非雷格子,同时避免踩雷,踩到一个雷即全盘皆输。
这个游戏对于c语言的初学者来说难度还是挺大的,那我就实现一个初学者也能快速学会的初级版扫雷游戏。

游戏设计

我们先创建三个文件

  1. game.h、game.c(游戏逻辑的实现)
    2.test.c(游戏功能测试)

这些是我们需要实现的游戏功能

//初始化棋盘
void InitBoard(char arr[ROWS][COLS], int rows, int cols, char set);
//打印棋盘
void DisPlayBoard(char arr[ROWS][COLS], int row, int col);
//布置雷
void SetMine(char arr[ROWS][COLS],int row, int col);
//排查雷
void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row,int col);

再次之前,我们在测试文件里先创建游戏菜单

//test.c
void meun()
{printf("******************\n");printf("***** 1.play  ****\n");printf("***** 0.exit  ****\n");printf("******************\n");
}

之后再实现菜单功能

void test()
{int input = 0;srand((unsigned int)(time(NULL)));do {meun();printf("请选择:>");scanf("%d", &input);switch(input){case 1:game();break;case 0:printf("游戏结束,退出游戏\n");break;default:printf("输入错误,请重新选择\n");break;}} while (input);
}

游戏规则:

1.如果这个位置是雷,那么游戏结束
2.如果把不是雷的位置都找出来了,那么游戏结束
3.如果这个位置不是雷,就计算这个位置的周围的8个格子有几个雷,并显示出雷的个数

我以一个9*9的的棋盘为例,在棋盘中,雷为1,非雷为0,如果我选中非雷,并且周围雷的数量为1,那么我如何区分呢?
其实创建两个棋盘就能解决了,一个棋盘放置雷的信息,一个棋盘给玩家展示,就能很好的解决。
在这里插入图片描述

//test.c
void game()
{//mine数组中存放布置好雷的信息char mine[ROWS][COLS] = { 0 };//数组全部初始化为字符'0'//show数组中存放排查出雷的信息char show[ROWS][COLS] = { 0 };//数组全部初始化为'*'//初始化棋盘InitBoard(mine, ROWS, COLS, '0');InitBoard(show, ROWS, COLS, '*');  //布置雷SetMine(mine, ROWS, COLS);//打印棋盘//DisPlayBoard(mine, ROW, COL);DisPlayBoard(show, ROW, COL);//排查雷FindMine(mine, show, ROWS, COLS);
}

然后我们初始化棋盘

//game.c
#include "game.h"//记得包含头文件
void InitBoard(char arr[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++){arr[i][j] = set;}}
}

打印棋盘

void DisPlayBoard(char arr[ROWS][COLS], int row, int col)
{int i = 0;printf("-------扫雷游戏--------\n");for (i = 0; i <= col; i++)//打印列{printf("%d ", i);}printf("\n");for (i = 1; i <= row; i++){int j = 0;printf("%d ", i);//打印行for (j = 1; j <= col; j++){printf("%c ", arr[i][j]);	}printf("\n");}
}

如果我们不打印行和列等会就无法定位坐标

在这里插入图片描述
然后就可以开始布置雷了
我们先实现简单版

//game.h
//行和列
#define ROW 9
#define COL 9#define ROWS ROW+2
#define COLS COL+2#define EASY_COUNT 10//雷的数量 

这里用rand因为是想随机布置雷,rand如何使用大家可以顺便了解一下

rand()和srand()的关系
rand()和srand()要一起使用,其中srand()用来初始化随机数种子,rand()用来产生随机数。
因为默认情况下随机数种子为1,而相同的随机数种子产生的随机数是一样的,失去了随机性的意义,所以为使每次得到的随机数不一样,用函数srand()初始化随机数种子。srand()的参数,用time函数值(即当前时间),因为两次调用rand()函数的时间通常是不同的,这样就可以保证随机性了。

//布置雷
void SetMine(char arr[ROWS][COLS], int row, int col)
{int count = EASY_COUNT;while (count){int x = rand() & row + 1;int y = rand() & col + 1;if (arr[x][y] == '0')arr[x][y] = '1';count--;}
}
//test.c
void test()
{int input = 0;srand((unsigned int)(time(NULL)));do {meun();printf("请选择:>");scanf("%d", &input);switch(input){case 1:game();break;case 0:printf("游戏结束,退出游戏\n");break;default:printf("输入错误,请重新选择\n");break;}} while (input);
}

排查地雷

//game.c
/*第一种方法
int GetMineCount(char arr[ROWS][COLS],int x, int y)
{int count = 0;for (int i = x - 1; i <= x + 1; x++){for (int j = y - 1; j <= y + 1; j++){count += (arr[x][y] - '0');}}return count;
}*/
//第二种
int GetMineCount(char mine[ROWS][COLS], int x, int y)
{return mine[x + 1][y] + mine[x - 1][y] +mine[x][y + 1] + mine[x][y - 1] +mine[x + 1][y + 1] + mine[x - 1][y + 1] +mine[x - 1][y - 1] + mine[x + 1][y - 1] - 8 * '0';
}
//排查雷
void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{int win = 0;int x = 0;int y = 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("倒霉鬼,你被炸死了");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");}}else{printf("请重新输入,坐标错误:");}}if (win == row * col - EASY_COUNT){printf("恭喜你,排雷成功!");DisPlayBoard(mine, ROW, COL);}}

源码:
game.h

#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 InitBoard(char arr[ROWS][COLS], int rows, int cols, char set);
//打印棋盘
void DisPlayBoard(char arr[ROWS][COLS], int row, int col);
//布置雷
void SetMine(char arr[ROWS][COLS],int row, int col);
//排查雷
void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row,int col);

game.c

#define _CRT_SECURE_NO_WARNINGS 1
#include "game.h"
void InitBoard(char arr[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++){arr[i][j] = set;}}
}void DisPlayBoard(char arr[ROWS][COLS], int row, int col)
{int i = 0;printf("-------扫雷游戏--------\n");for (i = 0; i <= col; i++){printf("%d ", i);}printf("\n");for (i = 1; i <= row; i++){int j = 0;printf("%d ", i);for (j = 1; j <= col; j++){printf("%c ", arr[i][j]);	}printf("\n");}
}
//布置雷
void SetMine(char arr[ROWS][COLS], int row, int col)
{int count = EASY_COUNT;while (count){int x = rand() & row + 1;int y = rand() & col + 1;if (arr[x][y] == '0')arr[x][y] = '1';count--;}
}int GetMineCount(char mine[ROWS][COLS], int x, int y)
{return mine[x + 1][y] + mine[x - 1][y] +mine[x][y + 1] + mine[x][y - 1] +mine[x + 1][y + 1] + mine[x - 1][y + 1] +mine[x - 1][y - 1] + mine[x + 1][y - 1] - 8 * '0';
}int GetMineCount(char arr[ROWS][COLS],int x, int y)
{int count = 0;for (int i = x - 1; i <= x + 1; x++){for (int j = y - 1; j <= y + 1; j++){count += (arr[x][y] - '0');}}return count;
}
//排查雷
void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{int win = 0;int x = 0;int y = 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("倒霉鬼,你被炸死了");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");}}else{printf("请重新输入,坐标错误:");}}if (win == row * col - EASY_COUNT){printf("恭喜你,排雷成功!");DisPlayBoard(mine, ROW, COL);}}

test.c

#define _CRT_SECURE_NO_WARNINGS 1#include "game.h"
void meun()
{printf("******************\n");printf("***** 1.play  ****\n");printf("***** 0.exit  ****\n");printf("******************\n");
}
void game()
{//mine数组中存放布置好雷的信息char mine[ROWS][COLS] = { 0 };//数组全部初始化为字符'0'//show数组中存放排查出雷的信息char show[ROWS][COLS] = { 0 };//数组全部初始化为'*'//初始化棋盘InitBoard(mine, ROWS, COLS, '0');InitBoard(show, ROWS, COLS, '*');  //这里是你字母打错了  现在可以了哦//布置雷SetMine(mine, ROWS, COLS);//打印棋盘//DisPlayBoard(mine, ROW, COL);DisPlayBoard(show, ROW, COL);//排查雷FindMine(mine, show, ROWS, COLS);
}
void test()
{int input = 0;srand((unsigned int)(time(NULL)));do {meun();printf("请选择:>");scanf("%d", &input);switch(input){case 1:game();break;case 0:printf("游戏结束,退出游戏\n");break;default:printf("输入错误,请重新选择\n");break;}} while (input);
}
int main()
{test();return 0;
}

运行效果:
在这里插入图片描述
希望这篇博客对你有所帮助!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/28554.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

黄仁勋最新建议:找到一门技艺,用一生去完善、磨炼!

“你可能会找到你的英伟达。我希望你们将挫折视为新的机遇。” 黄仁勋职业生涯中最大的教诲并非来自导师或科技公司 CEO&#xff0c;而是来自他在国际旅行时遇到的一位园丁。 近日在加州理工学院毕业典礼上发表演讲时&#xff0c;黄仁勋向毕业生分享了自己在日本京都的小故事。…

2012-2022年各省新质生产力指数数据(含原始数据+结果)

2012-2022年各省新质生产力指数数据&#xff08;含原始数据结果&#xff09; 1、时间&#xff1a;2012-2022年 2、指标&#xff1a;province、year、平均受教育年限、劳动者人力资本结构、高等院校在校学生结构、人均GDP元、在岗职工工资&#xff1a;元、三产从业人员比重、机…

各种机器学习算法的应用场景分别是什么(比如朴素贝叶斯、决策树、K 近邻、SVM、逻辑回归最大熵模型)?

2023简直被人工智能相关话题席卷的一年。关于机器学习算法的热度&#xff0c;也再次飙升&#xff0c;网络上一些分享已经比较老了。那么今天借着查询和学习的机会&#xff0c;我也来浅浅分享下目前各种机器学习算法及其应用场景。 为了方便非专业的朋友阅读&#xff0c;我会从算…

电子设计教程基础篇(电容)

文章目录 前言一、电容原理1.原理2.公式 二、电容种类1.结构1、固定电容2、可变电容3、微调电容 2.介质材料1、气体介质电容1、空气电容2、真空电容3、充气式电容 2、固体介质电容1、无机1、云母电容2、陶瓷电容1、瓷片电容2、独石电容 3、玻璃釉电容&#xff08;CI&#xff09…

爆火的治愈系插画工具又来了,额度居然有18w,根本花不完?

AI治愈插画又又又来了 今天给大家推荐一款完全免费的软件&#xff0c;用过的人都说好&#xff01; 先来看看我生成的图 制作过程非常简单&#xff0c;输入你想要生成的画面咒语。 工具地址&#xff1a;https://www.qiyuai.net/ 模型目前有两种 我上面的图就是用的第一种通用…

数据可视化案例

数据可视化案例 使用豆瓣电影中的数据来进行可视化&#xff0c;网址&#xff1a;豆瓣电影 Top 250 (douban.com) 一、网页数据分析 我们需要爬取的是豆瓣电影Top250网页每一页的电影名称、图片链接、导演、年份、国家、电影类型、电影评分这些数据。 在待爬取的网页中&#x…

通义千问调用笔记

如何使用通义千问API_模型服务灵积(DashScope)-阿里云帮助中心 package com.ruoyi.webapp.utils;import com.alibaba.dashscope.aigc.generation.Generation; import com.alibaba.dashscope.aigc.generation.GenerationOutput; import com.alibaba.dashscope.aigc.generation.G…

移动硬盘打不开怎么办?原因解析!

移动硬盘是一种方便携带、快速传输大量数据的存储设备。但有时我们会遇到这样的问题&#xff1a;插上电脑后&#xff0c;移动硬盘无法打开&#xff0c;出现各种错误提示。这时候我们该怎么办呢&#xff1f; 以下是一些可能导致移动硬盘打不开的原因及解决方法&#xff1a; 1.硬…

初始-Nativefier

--无奈只能靠自己 Nativefier 是什么&#xff1a; Nativefier 是一个命令行工具&#xff0c;仅仅通过一行代码就可以轻松地为任何的网站创建桌面应用程序&#xff0c;应用程序通过 Electron 打包成系统可执行文件&#xff08;如.app, .exe 等&#xff09;&#xff0c;可以运行在…

xx销售公司IT建设目标及IT规划方案(69页PPT)

方案介绍&#xff1a; 随着市场竞争的日益激烈&#xff0c;XX销售公司认识到信息化建设对于提升公司竞争力、优化业务流程、提高管理效率的重要性。次IT建设方案为XX销售公司带来了显著的业务效益和管理提升。我们将继续致力于推动公司的信息化建设&#xff0c;为公司的发展提…

Arthas线上环境问题排查定位工具

一、Arthas简介 Arthas是alibaba推出的一款JVM性能诊断调优的工具&#xff0c;也可以称之为是线上监控诊断产品&#xff0c;通过全局的视角可以实时的查看应用load、内存、GC、线程的状态信息&#xff0c;并且还可以在不修改应用代码的前提下&#xff0c;对业务问题进行诊断&a…

手把手教你如何在Windows11下安装Docker容器

文章的主要要点&#xff1a; 为什么使用Docker&#xff1a;Docker可以简化部署过程&#xff0c;特别适合新手或在学习新技能&#xff08;如Redis、MySQL、消息队列、Nginx等&#xff09;时使用。 安装前的准备&#xff1a;在安装Docker之前&#xff0c;需要在Windows中开启一些…

2024都市解压爆笑喜剧《脑洞大开》6月28日上映

随着暑期档的临近&#xff0c;电影市场迎来了一剂强心针——由何欢、王迅、克拉拉、卜钰、孙越、九孔等众多实力派笑星联袂主演的都市解压爆笑喜剧《脑洞大开》正式宣布定档&#xff0c;将于6月28日在全国各大影院欢乐上映&#xff0c;誓为观众带来今夏最畅快淋漓的笑声风暴。 …

代码随想录-Day32

122. 买卖股票的最佳时机 II 给你一个整数数组 prices &#xff0c;其中 prices[i] 表示某支股票第 i 天的价格。 在每一天&#xff0c;你可以决定是否购买和/或出售股票。你在任何时候 最多 只能持有 一股 股票。你也可以先购买&#xff0c;然后在 同一天 出售。 返回 你能…

MicroPython+ESP32 C3开发上云

传感器PinI/O状态D412输出1开0关D513输出1开0关 概述 MicroPython是python3编程语言的精简实现&#xff0c;能够在资源非常有限的硬件上运行&#xff0c;如MCU微控制器Micropython的网络功能和计算功能很强大&#xff0c;有非常多的库可以使用&#xff0c;它为嵌入式开发带来了…

FFmpeg编解码的那些事(3)-视频硬解码的基础知识

目录 前言&#xff1a; 1.iso/os x平台 2.windows平台 3.linux平台 4.Tips&#xff1a; 5.结论&#xff1a; 前言&#xff1a; 视频硬解码的过程就是把视频提取成图片变显示出来&#xff0c;就是播放器播放视频的过程&#xff0c;就可以理解为解码的过程。 在不同的系统…

【Android面试八股文】Java中有几种引用关系,它们的区别是什么?

在Java中,引用关系主要分为以下几种: 强引用(Strong Reference)软引用(Soft Reference)弱引用(Weak Reference)虚引用(Phantom Reference) 这些引用类型的区别在于它们对垃圾回收的影响程度。下面是对每种引用类型的详细解释及代码示例: 1. 强引用(Strong Referen…

LabVIEW、Matlab与Python的比较:从多角度详解三大编程工具

LabVIEW、Matlab和Python是工程和科学领域中常用的编程工具&#xff0c;各具特色。本文将从开发效率、计算性能、应用场景、学习曲线、成本和社区支持等多个角度&#xff0c;详细比较这三者的优缺点&#xff0c;帮助读者选择最适合其项目需求的编程工具。 比较维度 开发效率 La…

扫地机LiDAR形态之美

石头扫地机V20 LiDAR: Flash光源和Spot光源切换 图来自 Robot森 LiDAR(Light Detection and Ranging,激光雷达)技术在扫地机器人中的应用,不仅提升了机器的智能性和实用性,还展现了一种科技与艺术的融合之美。 一、外观设计的精致性 紧凑与轻巧:扫地机器人的LiDAR传感器…

C++ 43 之 自增运算符的重载

#include <iostream> #include <string> using namespace std;class MyInt{friend ostream& operator<< (ostream& cout , MyInt& int1); public:MyInt(){this->m_num 0;}// 前置自增&#xff1a; 成员函数实现运算符的重载 返回的是 引用&a…