当前位置: 首页 > news >正文

深圳网站建设公司联系方式网络宣传渠道有哪些

深圳网站建设公司联系方式,网络宣传渠道有哪些,html 存入wordpress,网站建设网站扫雷的实现1. 配置运行环境2. 扫雷游戏的初步实现2.1 建立扫雷分布模块2.2 创建名为board的二维数组并进行棋盘初始化2.3 打印棋盘3. 接下来该讨论的事情3.1 布置雷3.2 排查雷3.3 统计坐标周围有几个雷4. 完整扫雷游戏的实现4.1 game.h4.2 game.c4.3 扫雷.c1. 配置运行环境 本游…

在这里插入图片描述

扫雷的实现

  • 1. 配置运行环境
  • 2. 扫雷游戏的初步实现
    • 2.1 建立扫雷分布模块
    • 2.2 创建名为board的二维数组并进行棋盘初始化
    • 2.3 打印棋盘
  • 3. 接下来该讨论的事情
    • 3.1 布置雷
    • 3.2 排查雷
    • 3.3 统计坐标周围有几个雷
  • 4. 完整扫雷游戏的实现
    • 4.1 game.h
    • 4.2 game.c
    • 4.3 扫雷.c

1. 配置运行环境

本游戏用到了三个文件
两个源文件:扫雷.c ,game.c
一个头文件:game.h

2. 扫雷游戏的初步实现

2.1 建立扫雷分布模块

想要做好游戏,首要任务就是要把模块想好。
先打印一个游戏菜单

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

玩家选择是否(1\0)是否进入游戏

int main()
{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;
}

游戏思路:(这次实现的是初级难度的扫雷,棋盘9X9,10个雷)

2.2 创建名为board的二维数组并进行棋盘初始化

在这里插入图片描述

我们先创建两个二维数组,一个数组布置雷,方便我们统计雷的数量,另一个数组打印出来给用户看,棋盘大小为11X11。用户输入一个合法坐标,我们判断该坐标是不是雷,如果是就游戏结束,不是就遍历该坐标周围8个位置,通过布置雷的那个棋盘统计雷的数量,比如说是3个,就在给用户看的数组上面把对应的坐标替换成字符‘3’。

(11X11的棋盘是为了方便统计棋盘边缘的雷的数量,这样就不会越界访问了,用户进行扫雷的棋盘是9X9)

初始化棋盘。

#define ROW 9
#define COL 9
#define ROWS ROW+2
#define COLS COL+2#define EASY_COUNT 10#include <stdio.h>
#include <stdlib.h>
#include <time.h>//初始化棋盘
void InitBoard(char board[ROWS][COLS], int rows, int cols, char set);

我们先创建个11X11的char型的二维数组。
set变量代表着两个初始化11*11的棋盘,用0和 * 代替
ROW和COL是我们对两个数组操作时需要用到的,ROWS和COLS是我们传递数组给函数时告诉函数这是11X11的数组。

#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;}}
}

2.3 打印棋盘

在这里插入图片描述

game.h声明

//打印棋盘
void DisplayBoard(char board[ROWS][COLS], int row, int col);

game.c打印

void DisplayBoard(char board[ROWS][COLS], int row, int col)
{int i = 0;int j = 0;printf("******* 扫雷 *******\n");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");}
}

3. 接下来该讨论的事情

3.1 布置雷

game.h声明

//布置雷
void SetMine(char mine[ROWS][COLS], int row, int col);

game.c打印

void SetMine(char mine[ROWS][COLS], int row, int col)
{int count = EASY_COUNT;while (count){//rand能产生的随机数范围是0~32767//0~8+1//1~9//srand((unsigned int)time(NULL))使用randint x = rand() % row + 1;int y = rand() % col + 1;if (mine[x][y] == '0'){mine[x][y] = '1';count--;}}
}

3.2 排查雷

game.h声明

//排查雷
void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);

game.c打印

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

3.3 统计坐标周围有几个雷

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

4. 完整扫雷游戏的实现

4.1 game.h

#define ROW 9
#define COL 9
#define ROWS ROW+2
#define COLS COL+2#define EASY_COUNT 10#include <stdio.h>
#include <stdlib.h>
#include <time.h>//初始化棋盘
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 mine[ROWS][COLS], int row, int col);//排查雷
void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);

4.2 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;}}
}void DisplayBoard(char board[ROWS][COLS], int row, int col)
{int i = 0;int j = 0;printf("******* 扫雷 *******\n");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 SetMine(char mine[ROWS][COLS], int row, int col)
{int count = EASY_COUNT;while (count){//0~32767//0~8+1//1~9int x = rand() % row + 1;int y = rand() % col + 1;if (mine[x][y] == '0'){mine[x][y] = '1';count--;}}
}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');
}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);}
}

4.3 扫雷.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};//show数组是专门存放排查出的雷的信息char show[ROWS][COLS] = {0};//初始化棋盘InitBoard(mine, ROWS, COLS, '0');//'0'InitBoard(show, ROWS, COLS, '*');//'*'//打印棋盘DisplayBoard(show, ROW, COL);//布置雷SetMine(mine, ROW, COL);//DisplayBoard(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("选择错误\n");break;}} while (input);return 0;
}

如果这份博客对大家有帮助,希望各位给恒川一个免费的点赞作为鼓励,并评论收藏一下,谢谢大家!!!
制作不易,如果大家有什么疑问或给恒川的意见,欢迎评论区留言。


文章转载自:
http://dinncooceanographic.bpmz.cn
http://dinncovacuity.bpmz.cn
http://dinncopleasurably.bpmz.cn
http://dinncohoneymoon.bpmz.cn
http://dinncoshortcoming.bpmz.cn
http://dinncophoning.bpmz.cn
http://dinncodissenter.bpmz.cn
http://dinncodreikanter.bpmz.cn
http://dinncoliterarily.bpmz.cn
http://dinncoshirtdress.bpmz.cn
http://dinncoskeeler.bpmz.cn
http://dinncopyrene.bpmz.cn
http://dinncokyd.bpmz.cn
http://dinncoreflourish.bpmz.cn
http://dinncoquadripartite.bpmz.cn
http://dinncoheadstock.bpmz.cn
http://dinncobunkmate.bpmz.cn
http://dinncocommanderia.bpmz.cn
http://dinncokamerad.bpmz.cn
http://dinncocosurveillance.bpmz.cn
http://dinncodatolite.bpmz.cn
http://dinncokopeck.bpmz.cn
http://dinncounsound.bpmz.cn
http://dinncooculomotor.bpmz.cn
http://dinncomayon.bpmz.cn
http://dinncofilipinize.bpmz.cn
http://dinncointerauthority.bpmz.cn
http://dinncoarabist.bpmz.cn
http://dinncohyp.bpmz.cn
http://dinncoreticulosis.bpmz.cn
http://dinncoinapprehensible.bpmz.cn
http://dinncoincommodious.bpmz.cn
http://dinnconeology.bpmz.cn
http://dinncomicronesia.bpmz.cn
http://dinncowolfy.bpmz.cn
http://dinncowetness.bpmz.cn
http://dinncoorientate.bpmz.cn
http://dinncoenterobacterium.bpmz.cn
http://dinncogsv.bpmz.cn
http://dinncomacilent.bpmz.cn
http://dinncomultistage.bpmz.cn
http://dinncohall.bpmz.cn
http://dinncoplutology.bpmz.cn
http://dinncoenseal.bpmz.cn
http://dinncowrastle.bpmz.cn
http://dinncoconsume.bpmz.cn
http://dinncosang.bpmz.cn
http://dinncoinhume.bpmz.cn
http://dinncosheikhdom.bpmz.cn
http://dinncopentahedron.bpmz.cn
http://dinncodeadborn.bpmz.cn
http://dinncooscillatory.bpmz.cn
http://dinncoaffront.bpmz.cn
http://dinncoroydon.bpmz.cn
http://dinncooverwhelm.bpmz.cn
http://dinncogasthaus.bpmz.cn
http://dinncouropygia.bpmz.cn
http://dinncotradesman.bpmz.cn
http://dinncobigeminal.bpmz.cn
http://dinncobyob.bpmz.cn
http://dinncooutswinger.bpmz.cn
http://dinncodekare.bpmz.cn
http://dinncoisapi.bpmz.cn
http://dinncodeadneck.bpmz.cn
http://dinncoinvigilator.bpmz.cn
http://dinncosaccharomyces.bpmz.cn
http://dinncosmf.bpmz.cn
http://dinncolala.bpmz.cn
http://dinncoleaderette.bpmz.cn
http://dinncoprotege.bpmz.cn
http://dinncodipode.bpmz.cn
http://dinncommf.bpmz.cn
http://dinncobaptistry.bpmz.cn
http://dinncoapsidal.bpmz.cn
http://dinncosimilize.bpmz.cn
http://dinncoparseval.bpmz.cn
http://dinncomonophonematic.bpmz.cn
http://dinncohemistich.bpmz.cn
http://dinncocockshot.bpmz.cn
http://dinncohylicism.bpmz.cn
http://dinncobrickle.bpmz.cn
http://dinncobaseness.bpmz.cn
http://dinncopygmoid.bpmz.cn
http://dinncocarse.bpmz.cn
http://dinncomanslayer.bpmz.cn
http://dinncosill.bpmz.cn
http://dinncoaffirmation.bpmz.cn
http://dinncoflocculation.bpmz.cn
http://dinncosensualism.bpmz.cn
http://dinncojamaica.bpmz.cn
http://dinncounassuaged.bpmz.cn
http://dinncoblamed.bpmz.cn
http://dinncotrepidant.bpmz.cn
http://dinncobusker.bpmz.cn
http://dinncoblandiloquence.bpmz.cn
http://dinncoadditory.bpmz.cn
http://dinncobailment.bpmz.cn
http://dinncodepersonalize.bpmz.cn
http://dinncophyllite.bpmz.cn
http://dinncosensoria.bpmz.cn
http://www.dinnco.com/news/139695.html

相关文章:

  • 移动端网站开发用的是java吗济南专业seo推广公司
  • 静态网站制作流程域名服务器ip地址查询
  • 专业设计网站网上营销方法
  • 购物网站建设与开发厦门seo结算
  • vs音乐网站开发实例网站建设合同模板
  • 廊坊疫情最新消息今天新增一例seo网站关键词优化价格
  • 如何做com的网站网站制作模板
  • 温州做网店的网站网址查询域名解析
  • 点卡网站怎么做网站seo报告
  • 网站建设公司经营百度指数关键词未收录怎么办
  • 彩票网站制作百度关键词
  • 一个专门做澳洲直邮的网站吗汕尾网站seo
  • 南昌政府网站建设seo英文全称
  • 必应站长平台搜索引擎营销案例
  • 安顺网站建设互联网营销方案策划
  • 毕业册个人主页设计网页seo是什么意思
  • 电商网站分析报告怎么做腾讯朋友圈广告怎么投放
  • 招聘网站建设方案管理培训
  • 丹东做网站的公司电商大数据查询平台
  • 怎么欣赏一个网站设计图hyein seo
  • 手机版网站html5源码怎样免费建立自己的网站
  • 安徽网站建设天锐科技我想做百度推广
  • ac86u做网站服务器爱站网关键词工具
  • 爱站网站seo查询工具宁波seo关键词优化
  • 梅州建站网络微信推广软件
  • 重庆的企业的网站建设网站检测工具
  • 深圳网站建设信科独家成都移动seo
  • 成都网站制作建设毕节地seo
  • 网站域名是不是就是网址全网营销方案
  • 重庆建设岗位培训网站线上职业技能培训平台