首页 > 其他分享 >《初学C语言第18天——扫雷游戏特别篇》

《初学C语言第18天——扫雷游戏特别篇》

时间:2023-12-09 17:31:32浏览次数:31  
标签:ROWS 特别篇 int 18 COLS mine char printf C语言

//(game.h.cpp)

#define _CRT_SECURE_NO_WARNINGS 1

#define ROW 9

#define COL 9

#define ROWS ROW+2

#define COLS COL+2

#define LEI 10//雷的个数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);//此处的[][]要与对应数组保持一致,而int**可以更改

void SetMine(char board[ROWS][COLS], int row, int col);

void FindMine(char mine[ROWS][COLS],char show[ROWS][COLS],int row,int col);//由于关系到两个数组,所以不再用board,直接引用两个数组


//(game.c.cpp)

#include"game.h.cpp"

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;//此处使用*而不是0的原因是,mine数组排查完之后*变成0,而show数组还未排查

  //所以使board[i][j] =set(设置),set为初始函数的字符,这样在后续初始化函数时就可以随意定义‘0或者'*'

 }

}

}

void DisplayBoard(char board[ROWS][COLS], int row, int col)

{

int i = 0;

int j = 0;

for (i = 0; i <= col; i++)

{

 printf("%d ", i);//打印出列号

}

printf("\n");//换行

for (i = 1; i <= row; i++)//此时行列已经变成9,所以,数组的第一个坐标也就变成了(1,1),所以此处i为1

{

 printf("%d ", i);//打印行号

 for (j = 1; j <= col; j++)

 {

  printf("%c", board[i][j]);

 }

printf("\n");

}

}

void SetMine(char board[ROWS][COLS], int row, int col)

{

int count = LEI;//为了方便改变雷的个数,使用LEI,只需在头文件中改变即可

while (count)

{

 int x = rand() % row + 1;//可放雷的范围是9/9(在没放过雷的位置存放雷),首位置是(1,1),每放一个雷,LEI--(减1,直至0)

 int y = rand() % col + 1;//rand随机值,x,y取值范围x<=row,y<=col,so,rand()%(row或col)+1,就是x,y的范围

 if (board[x][y] == '0')

 {

  board[x][y] = '1';

  count--;

 }

}//rand()函数使用之前要先调用srand

}

//'0'-'0'=0

//'1'-'0'=1

//'3'-'0'=3

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;

//共有10个雷,71个位置没有雷

while (win<row*col-LEI)

{

 printf("请输入排查雷的坐标:>");

 scanf("%d%d", &x, &y);

 if (x >= 1 && x <= row && y >= 1 && y <= col)//判断坐标是否合法

 {

  //踩雷了

  if (mine[x][y] == '1')

  {

   printf("很遗憾,你被炸死了!\n");//由于玩家不知道自己为什么被炸死,所以打印出雷的信息

   DisplayBoard(mine,row,col);

   break;//游戏结束

  }

  else//没踩到雷

  {

   //计算x,y周围有几个雷

   int count=get_mine_count(mine,x,y);

   show[x][y] = count + '0';

   DisplayBoard(show, row, col);

   win++;

  }

 }

 else

 {

  printf("输入坐标非法,请重新输入!\n");

 }

}

if (win == row * col -LEI)

{

 printf("恭喜你,排雷成功了!\n");

}

}



//(test.c.cpp)

#include"game.h.cpp"

void menu()//建立菜单

{

printf(" * * * * * * * * * * * * * * * * * * * * * * * * * * * * \n");

printf(" * * * *  1.play    0.exit  * * * * \n");

printf(" * * * * * * * * * * * * * * * * * * * * * * * * * * * *\n");

}

void game()

{

//雷的信息储存

//1.布置好的-雷的信息(数组名-mine),包含附加圈

char mine[ROWS][COLS] = { 0 };//数组大小为11*11,包含附加圈

//2.排查出的-雷的信息(数组名-show),不包含附加圈

char show[ROWS][COLS] = { 0 };//数组大小为11*11

//初始化

InitBoard(mine, ROWS, COLS, '0');//让show和mine都为11,11,是为了相同数组,对应位置坐标相同,减少下标的二次更改

InitBoard(show, ROWS, COLS, '*'); //由于让set为初始函数的字符,这样在后续初始化函数时就可以随意定义‘0或者'*'

//打印棋盘

//DisplayBoard(mine,ROW,COL);//此时打印不需要打印最外的附加圈,so,此时为9,9

DisplayBoard(show, ROW, COL);

//虽然打印棋盘时用的是9,9的格式,但是语法规定引用数组就应与初始设定保持一致。

// 如需改变,直接改变实参(ROW/ROWS、COL/COLS)即可

//布置雷

SetMine(mine, ROW, COL);//雷在9,9里

//DisplayBoard(mine, ROW, COL)正式扫雷程序中没有这一步

//扫雷

FindMine(mine,show,ROW,COL);//在mine数组中查找信息存储到show数组里面去(因为要操作两个数组,所以两个数组都要传过去)

}


void test()

{

int input = 0;

srand((unsigned int)time(NULL));//srand不能频繁调用,调用一次即可

//用time的fan'hui'zhi

do//可以玩完一把再继续玩,do,while的结构

{

 menu();//菜单menu

 printf("请选择:>");

 scanf("%d", &input);

 switch (input)

 {

 case 1:

  game();//简易的函数:game—>完成此游戏的代码

  break;

 case 0:

  printf("退出游戏\n");

  break;

 default:

  printf("选择错误,重新选择!\n");

 }

} while (input);

}

int main()

{

test();

return 0;

}

标签:ROWS,特别篇,int,18,COLS,mine,char,printf,C语言
From: https://blog.51cto.com/KKhahaha/8750998

相关文章

  • 【C语言】编译和链接
    1、翻译环境和运行环境在ANSIC的任何⼀种实现中,存在两个不同的环境。第1种是翻译环境,在这个环境中源代码被转换为可执行的机器指令。第2种是执行环境,它⽤于实际执行代码。2、翻译环境那翻译环境是怎么将源代码转换为可执⾏的机器指令的呢?这里我们就得展开开讲解⼀下翻译环境所做......
  • PTA|C语言|结构体
    --------------------------------------------------------------------------------计算两个复数之积本题要求实现一个计算复数之积的简单函数。函数接口定义:structcomplexmultiply(structcomplexx,structcomplexy);其中structcomplex是复数结构体,其定义如下:structcompl......
  • CF1894E Freedom of Choice
    CF1894E数据范围多少有点诈骗首先考虑\(m=1\)的情况容易发现这个\(l_i,r_i\leq10^{17}\)不是很对劲,因为直觉上感觉如果区间可取范围过大答案就是\(0\)我们可以取一个不是那么严格的限制条件来约束他,当\(r-l>n\)时,答案肯定是\(0\)。这样我们就把区间长度取到了\(10^......
  • JOISC2018 题解
    ContestLinkA.ConstructionofHighwayProblemLink题目大意给\(n\)个点,初始每个点有权值\(w_i\),\(n-1\)次操作连一条边\(u\getsv\),其中\(u\)与\(1\)连通,\(v\)与\(1\)不连通,求\(1\tou\)路径上权值的逆序对数,然后把路径权值推平为\(v\)的权值。数据范围......
  • CF1838C No Prime Differences 题解
    题意:思路:构造:$n$行$m$列,先填奇数行,每行填$m$个,第$2i-1$行依次填入$(i-1)\cdotm+1$,$(i-1)\cdotm+2$,$...$,$i\cdotm-1$,$i\cdotm$,剩下的依次填入偶数行即可。证明:构造完成后,对于每行,相邻两项的差值均为$1$,一定不为......
  • CF1894D Neutral Tonality
    CF1894D退役之后啥也不会了/kk首先容易想到\(b_i\)递减插入更优。考虑答案的下界显然是\(LCA(a)\),答案的上界为\(LCA(a)+1\),因为我们总是可以在任意位置插入递减的\(b_i\)来得到。因此我们只需要考虑怎么判断当前答案取上界还是下界即可。实际上,答案的下界是始终......
  • P1854-DP【绿】
    首先通过这道题我收获了一个知识,那就是deque可以直接赋值,作用和vector类似就是复制一个一摸一样的deque,很好用,越来越发现deque眉清目秀了起来。以后deque可能是我最常用的STL结构了。毕竟queue、stack都用deque来实现明显更方便而且不会多占用什么空间的。一眼便能看出,这道题用记......
  • 通过C语言的API预处理管理MySQL
    一、C的API预处理语句MySQL客户端/服务器协议提供了预处理语句。该功能采用了由mysql_stmt_init()初始化函数返回的MYSQL_STMT语句处理程序数据结构。对于多次执行的语句,预处理执行是一种有效的方式。首先对语句进行解析,为执行作好准备。接下来,在以后使用初始化函数返回的语句句柄......
  • 12.9 蓝桥杯 huffuman树c语言
    今天学习了蓝桥杯的huffuman树,总结如下:问题描述Huffman树在编码中有着广泛的应用。在这里,我们只关心Huffman树的构造过程。给出一列数{pi}={p0,p1,…,pn-1},用这列数构造Huffman树的过程如下:1.找到{pi}中最小的两个数,设为pa和pb,将pa和pb从{pi}中删除掉,然后将它们的和加......
  • 【LGR-168-Div.4】洛谷入门赛 #18
    打表过样例题目描述很不幸,你遇到了不负责任的出题人。在某道试题里,共有\(N\)个测试点,组成了\(k\)个Subtask,第\(i\)个Subtask包含\(p_i\)个测试点,第\(j\)个测试点的编号为\(w_{i,j}\)。请注意,一个测试点可能属于多个Subtask。Subtask每个Subtask包含多个测......