游戏实践:扫雷

一.游戏介绍

虽然很多人玩过这个游戏,但还是介绍一下。在下面的格子里,埋的有10颗雷,我们通过鼠标点击的方式,点出你认为不是雷的地方,等到把所有没有雷的格子点完之后,及视为游戏胜利。

上面的数字的意思就是它的一圈的格子有几颗雷。 

 明白了游戏的玩法,那么我们就可以来写一下这个游戏。

二.游戏的实现

我们首先来创建三个文件,分别是用来实现游戏内容的头文件game.c,来测试的text.c文件,还有头文件game.c。

1.游戏的大纲(text.c)

我们可以先把游戏大体的思路给顺下来:

比如在正式写游戏内容的实现之前,我们是不是需要写一下游戏的目录(按1开始游戏,或者按0退出游戏之类的)。

(1)目录(menu函数)

像是游戏的目录:

void menu()
{printf("**********************\n");printf("***** 1. play    *****\n");printf("***** 0. exit    *****\n");printf("**********************\n");
}

(2)选择开始与结束(text函数)

我想让他按1开始游戏,按0退出游戏,我是不是就可以用一个do  while循环来实现:

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

 (3)游戏内部需要做的(game函数)

此时我想按1来进行游戏,我是不是就可以在1的后面加上一个game()函数,来实现游戏内容。我们在game.c文件里实现好这些功能后,在这个函数里直接调用就行了。

注意:这里看不懂没关系,只是想让大家知道这个游戏我们要干啥。

要实现游戏内容,我们就需要初始化棋盘,布置雷,打印棋盘,排查雷。这些都是在game.c文件里来实现,最后在text.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, '*');//布置雷//就9*9的棋盘上随机布置10个雷SetMine(mine, ROW, COL);//DisplayBoard(mine, ROW, COL);//打印棋盘DisplayBoard(show, ROW, COL);//排查雷FindMine(mine, show, ROW, COL);
}

2.游戏内容的实现

先把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 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);

(1)初始化棋盘

我们创建一个函数来初始化我们的棋盘:共有四个参数

第一个参数就是我们的棋盘。

第二个参数是我们棋盘的行。

第三个参数是我们棋盘的列。

第四个参数是我们需要把棋盘初始化成什么(比如0,*)。

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;//两个for循环实现整个棋盘的初始化}}
}

(2)打印棋盘

这个函数需要三个参数:分别是棋盘,行和列。

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");}
}

(3)布置棋盘

这个步骤就很重要了,因为是我们布置雷的过程。

我们想要随机的布置雷的方位,我们就需要利用好time.h。

void SetMine(char arr[ROWS][COLS], int row, int col)
{int count = EASY_COUNT;while (count){int x = rand() % row + 1;//这里的rand函数需要与srand函数配合使用,目的就是生成一个随机数int y = rand() % col + 1;//这里的x和y的范围都是1~10if (arr[x][y] == '0'){arr[x][y] = '1';//注意这里的1和0都是字符count--;}}
}

注意:在使用rand函数生成随机数之前,通常需要调用srand函数来设置随机数种子。随机数种子是一个起始值,它会影响后续rand函数生成的随机数序列。如果每次程序运行时都使用相同的随机数种子,那么每次生成的随机数序列都会相同。

(4)知道雷的数量

因为当我们扫到一个雷的时候,会反馈给我们周围雷的数量,所以要有那么一个步骤:

我们可以把每一个格子都加起来,看看有几个1。

static int GetMineCount(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';
}

如果用上面的方式,会显得有点麻烦,还可以这样写: 

static int GetMineCount(char mine[ROWS][COLS], int x, int y)
{int i = 0;int count = 0;for (i = x - 1; i <= x + 1; i++){int j = 0;for (j = y - 1; j <= y + 1; j++){count += (mine[i][j] - '0');//因为是字符1,所以我们要减去字符0,得到数字1}}return count;
}

(5)排查雷

四个参数:一个是有0和1的参数,一个是让玩家看的参数,另外两个是行和列。

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");DisplayBoard(mine, ROW, COL);//被炸死了直接把带有雷的棋盘弄出来break;}else{//该坐标不是雷,就得统计坐标周围有几个雷int count = GetMineCount(mine, x, y);show[x][y] = count + '0';//我们的count是数字,所以要加上字符0的ASCII码值DisplayBoard(show, ROW, COL);win++;}}else{printf("该坐标已经被排查了,重新输入坐标\n");}}else{printf("坐标非法,请重新输入\n");}}if (win == row * col - EASY_COUNT){printf("恭喜你,排雷成功\n");DisplayBoard(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 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);

text.c文件:

#include "game.h"void menu()
{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, '*');//布置雷//就9*9的棋盘上随机布置10个雷SetMine(mine, ROW, COL);//DisplayBoard(mine, ROW, COL);//打印棋盘DisplayBoard(show, ROW, COL);//排查雷FindMine(mine, show, ROW, COL);
}void test()
{int input = 0;srand((unsigned int)time(NULL));do{menu();printf("请选择:>");scanf("%d", &input);//1 0 xswitch (input){case 1:game();break;case 0:printf("游戏结束,退出游戏\n");break;default:printf("选择错误,重新选择\n");break;}} while (input);
}int main()
{test();return 0;
}

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");}
}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--;}}
}static int GetMineCount(char mine[ROWS][COLS], int x, int y)
{int i = 0;int count = 0;for (i = x - 1; i <= x + 1; i++){int j = 0;for (j = y - 1; j <= y + 1; j++){count += (mine[i][j] - '0');}}return count;
}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");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("坐标非法,请重新输入\n");}}if (win == row * col - EASY_COUNT){printf("恭喜你,排雷成功\n");DisplayBoard(mine, ROW, COL);}
}

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

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

相关文章

【前端CSS基础2(CSS基本选择器和复合选择器)】

前端CSS基础2&#xff08;CSS基本选择器和复合选择器&#xff09; HTML和HTML的区别和联系HTML元素和CSS属性CSS基本选择器ID选择器类选择器标签选择器群组选择器通配选择器层次选择器属性选择器伪类选择器伪元素选择器 CSS复合选择器交集选择器并集选择器后代选择器子元素选择…

华院计算参编《金融业人工智能平台技术要求》标准

随着人工智能技术的迅猛发展&#xff0c;金融机构正在从业务场景化向企业智能化演进&#xff0c;金融业对智能化的需求愈加迫切。为引导产业有序发展、规范行业自律、加快金融行业智能化转型&#xff0c;中国信通院依托中国人工智能产业发展联盟&#xff08;AIIA&#xff09;及…

auto的工作原理

类型推导&#xff1a; 当使用 auto 关键字声明变量时&#xff0c;编译器会根据变量初始化的表达式推导出其类型。编译器会分析初始化表达式&#xff0c;并根据表达式的类型来确定变量的类型。 类型保留&#xff1a; 编译器在编译时将 auto 关键字替换为实际的类型&#xff0c;…

CommunityToolkit.Mvvm笔记---Ioc

使用MVVM模式提高应用程序代码库中的模块化程度的最常用模式是使用某种形式的反转控制&#xff08;Ioc&#xff09;。其中最常见的解决方案是使用依赖关系注入&#xff0c;该解决方案存在于创建多个注入后端类的服务&#xff08;即以参数的形式传递给 viewmodel 构造函数&#…

ELK+Filebeat日志分析系统

一、ELK基本介绍&#xff1a; 1.ELK 简介: ELK平台是一套完整的日志集中处理解决方案(日志系统)。 将 ElasticSearch、Logstash 和 Kiabana 三个开源工具配合使用&#xff0c; 完成更强大的用户对日志的查询、排序、统计需求。 ELK --> ELFK --> ELFKMQ2.ELK组件介绍…

IDEA创建jsp文件具体步骤

1. 创建普通项目 2.文件->项目结构->模块&#xff0c;点击号&#xff0c;选择web 点击确认 3.配置工件 4.配置tomcat 点击确定 5.创建jsp文件&#xff0c;注意创建位置 6.然后换调试位置 注意此时不能有其他的web项目运行,否则就选不了路径 完成后运行即可

Python代码打包成exe程序

国内镜像源 清华大学 https://pypi.tuna.tsinghua.edu.cn/simple阿里云 https://mirrors.aliyun.com/pypi/simple/豆瓣 https://pypi.douban.com/simple/ 百度云 https://mirror.baidu.com/pypi/simple/中科大 https://pypi.mirrors.ustc.edu.cn/simple/华为云 https://mirror…

Pytorch - 张量转换拼接

目录 张量转换为 numpy 数组 numpy 转换为张量 标量张量和数字的转换 张量拼接操作 张量索引操作 &#x1f606;&#x1f606;&#x1f606;感谢大家的观看&#x1f606;&#x1f606;&#x1f606; 张量转换为 numpy 数组 &#x1f50e;使用 Tensor.numpy 函数可以将张量…

Gradle JDK 和项目JDK的区别

compileOptions { sourceCompatibility JavaVersion.VERSION_1_8 targetCompatibility JavaVersion.VERSION_1_8 } kotlinOptions { jvmTarget “1.8” } 在Android项目中&#xff0c;compileOptions和kotlinOptions的配置与Gradle所使用的JDK版本没有直接冲突。这些选项是用…

MySQL 使用C语言

一般使用MySQL很少用命令行&#xff0c;一般都是通过程序内部使用&#xff0c;MySQL也为不同的语言定制了不同的头文件和库函数&#xff0c;可以在自己的程序中通过包含头文件和编译时候链接库函数来使用MySQL。 现在一般安装MySQL的时候就会自动给你安装库函数和头文件。 可…

数据资产管理制度探索——浙江篇

在行政事业单位数据资产管理领域&#xff0c;浙江省以创新性思维与高质量发展的战略眼光&#xff0c;积极探索并构建了具有前瞻性和实效性的数据资产管理制度。作为财政部数据资产管理试点省份&#xff0c;浙江省财政厅与省标准化研究院强强联合&#xff0c;充分运用数据溯源、…

【报错】TypeError: Cannot read property ‘meta‘ of undefined

&#x1f608;解决思路 首先这里很明显我们能看到是缺少该参数&#xff1a;meta。 但是经过查找后发现和该参数无关。 &#x1f608;解决方法 后来我上网搜了下&#xff0c;网上的回答大部分偏向于是package.json这个文件中的tabBar.list数组对象只有一条的问题。 网上的大…

基于SpringBoot + Vue实现的租房管理系统设计与实现+毕业论文+开题报告​(包运行成功)

介绍 管理员的主要功能设计为&#xff1a;密码信息管理、注册用户管理、区域管理、出租管理等模块。 房主的主要功能设计为&#xff1a;密码信息管理、个人信息管理、订单管理等模块。 用户的主要功能设计为&#xff1a;用户登录、密码管理、出租管理、收藏管理等模块。 源码论…

数据结构---线性表

1&#xff0c;顺序表实现---动态分配 #include<stdlib.h> #define InitSize 10 typedef struct {int *data;//静态分配int length;int MaxSize; }SqList; void InitList(SqList& L) {L.data (int*)malloc(InitSize * sizeof(int));//分配空间L.length 0;L.MaxSize…

编译 dtbocfg 模块是遇到的问题

编译 dtbocfg 模块 报错1 在编译 dtbocfg.c CC [M] /home/book/imx6ull/kernal_modul/00_dtbocfg/dtbocfg.o /home/book/imx6ull/kernal_modul/00_dtbocfg/dtbocfg.c:253:1: warning: data definition has no type or storage classCONFIGFS_ATTR(dtbocfg_overlay_item_, dt…

【测试开发学习历程】python常用的模块(上)

前言&#xff1a; 感觉全是机器人给我点赞和收藏&#xff08;QWQ&#xff09;&#xff0c;能不能来个活人评论我啊&#xff0c;行行好&#xff08;QAQ&#xff09; 目录 1 模块的导入 2 随机模块-random 3 字符串模块-string 4 os模块及其常用函数 1 模块的导入 库、包、…

关于SpringCloud,你了解多少?

Why SpringCloud&#xff1f; Spring cloud 是一系列框架的有序集合。它利用 spring boot 的开发便利性巧妙地简化了分布式系统基础设施的开发&#xff0c;如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等&#xff0c;都可以用 spring boot 的开发风格做到一…

C++ 标准库中的 <algorithm> 头文件

C 标准库中的 <algorithm> 头文件包含了一系列非常有用的算法函数&#xff0c;这些函数可以用于处理容器&#xff08;如向量、列表、数组等&#xff09;中的元素。这些算法可以极大地简化编程任务&#xff0c;使代码更加简洁和易于理解。 以下是一些 <algorithm> …

论坛直击|发展新质生产力,高校怎么做?

新质生产力浪潮涌动 三大议题聚焦高校人才培养 今年全国两会的政府工作报告将“大力推进现代化产业体系建设&#xff0c;加快发展新质生产力”列在2024年政府工作任务首位&#xff0c;发展新质生产力的先导是培养拔尖创新人才&#xff0c;高等教育改革必须以立德树人为根本任…

带你从BIOS 小工到年薪百万 之 sense amplifier 的作用以及MRC 如何初始化它

做过BIOS 的同学&#xff0c;肯定看过这张图片 对世界充满好奇心的你&#xff0c;是否想过 其中 Sense amplifier 是做什么用的&#xff1f; 是如何工作的&#xff1f; BIOS 又是如何训练它的&#xff1f; 明天接着写