成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

【C語(yǔ)言/入門(mén)游戲】掃雷完整版(包含標(biāo)記,安全保護(hù)及展開(kāi))

0x584a / 945人閱讀

摘要:有雷則返回雷數(shù)難度設(shè)置其實(shí)實(shí)現(xiàn)思路比較簡(jiǎn)單,可以再設(shè)置和。

知識(shí)提要(自主編寫(xiě)游戲所需要的知識(shí)):

1.函數(shù)的基本實(shí)現(xiàn);

2.二維數(shù)組;

目錄

掃雷

1.基本界面的實(shí)現(xiàn)

2.初始化棋盤(pán)(二維數(shù)組)

3.棋盤(pán)的打印

4.布置雷

5.安全保護(hù)

6.雷數(shù)顯示

7.排查雷

8.標(biāo)記雷

9.展開(kāi)

10.難度設(shè)置

11.全局代碼


掃雷

效果圖:

?從以上效果圖中可見(jiàn),我們需要實(shí)現(xiàn)的功能有:

1.隨機(jī)埋雷

2.顯示雷數(shù)

3.展開(kāi)

4.標(biāo)記

5.判定輸贏

如果將雷,數(shù)字,和*同時(shí)放在一個(gè)數(shù)組里是不現(xiàn)實(shí)的,因?yàn)槿绻粋€(gè)格子中已經(jīng)放了雷,就不可能將其變?yōu)樾翘?hào)顯示,所以我們得到一個(gè)大體思路,要用兩個(gè)數(shù)組,一個(gè)埋雷,一個(gè)顯示。

還是老規(guī)矩,創(chuàng)建3個(gè)文件

game.h先引用和定義必要的數(shù)據(jù)

# define _CRT_SECURE_NO_WARNINGS#include #include #include #define ROW 9#define COL 9#define ROWS ROW+2#define COLS COL+2#define EASY_COUNT 10

這次我們用"*"當(dāng)作未知量,"#"為標(biāo)記,"1"為雷,"0"為非雷(此處為一個(gè)伏筆)

1.基本界面的實(shí)現(xiàn)

這一部分比較簡(jiǎn)單,所以就只簡(jiǎn)單提一句

void menu(){	printf("*********************************/n");	printf("*********    1. Play    *********/n");	printf("*********    0. Exit    *********/n");	printf("*********************************/n");	}void game(){	char mine[ROWS][COLS] = { 0 };//存放雷的信息	char show[ROWS][COLS] = { 0 };//展示給玩家的棋盤(pán)	intialize(mine,ROWS ,COLS,"0");	intialize(show,ROWS ,COLS,"*");	//展示棋盤(pán)	print(show, ROW, COL);		//布置雷	setmine(mine, ROW, COL);		//排查	search(mine, show, ROW, COL,0);}int main(){	int input = 0;	srand((unsigned int)time(NULL));	do	{		menu();		printf("請(qǐng)選擇>:");		scanf("%d", &input);		switch (input)		{		case 1:			printf("game start/n");			game();			break;		case 0:			printf("已退出游戲/n");			break;		default:			printf("選擇錯(cuò)誤,請(qǐng)重新選擇/n");			break;		}	} while (input);	return 0;}

這里可能有人要問(wèn),為什么要?jiǎng)?chuàng)建11*11的數(shù)組呢?

如果我們要在9*9的棋盤(pán)中找尋雷的個(gè)數(shù),那么就得找尋周?chē)?個(gè)元素,但是如果要找邊邊角角的格子附件雷的個(gè)數(shù),就涉及到數(shù)組越界的問(wèn)題,不太好辦。所以我們將數(shù)組做大一圈,保證數(shù)組訪問(wèn)不會(huì)越界

2.初始化棋盤(pán)(二維數(shù)組)

現(xiàn)在我們要考慮一個(gè)問(wèn)題,這次我們有兩個(gè)二維數(shù)組要初始化,而且其中內(nèi)容也不同,那該怎么辦呢?

其實(shí)也比較簡(jiǎn)單,只需要讓初始化函數(shù)多接受一個(gè)需要初始化的量就可以了

void intialize(char board[ROWS][COLS], int row, int col, char target){	int i = 0;	for (i = 0; i < row; i++)	{		int j = 0;		for (j = 0; j < col; j++)		{			board[i][j] = target;		}	}}

這樣就可以完成不同的初始化了

3.棋盤(pán)的打印

由于掃雷需要的棋盤(pán)比較大,為了方便游玩,這次還需要打印行列號(hào)

void print(char board[ROWS][COLS], int row, int col){	int i = 0;	for (i = 0; i <= row; i++)//打印列號(hào)	{		printf("%d ", i);	}	printf("/n");	for (i = 1; i <= row; i++)	{		int j = 0;		printf("%d ", i);//打印行號(hào)		for (j = 1; j <= col; j++)		{			printf("%c ", board[i][j]);		}		printf("/n");	}}

效果圖:

4.布置雷

布置雷就牽扯到隨機(jī)數(shù)的問(wèn)題,要保證雷不會(huì)重復(fù)布置且只在9*9的棋盤(pán)中布置

void setmine(char board[ROWS][COLS], int row, int col){	int x = 0;	int y = 0;	int count = 0;	while (1)//未布置滿就一直循環(huán)	{		x = rand() % row + 1;//使x,y在1~9間,保證數(shù)組不越界布置		y = rand() % col + 1;		if (board[x][y] != "1")//保證布置的雷不重復(fù)		{			board[x][y] = "1";			count++;		}		if (count == EASY_COUNT)//布置滿所有不重復(fù)的雷后才可跳出循環(huán)			break;	}}

5.安全保護(hù)

為了防止第一次排查就猝死,提高游戲體驗(yàn)所以我們需要設(shè)計(jì)一下,讓玩家如果第一次就踩雷,棋盤(pán)會(huì)重置,直到此處沒(méi)有雷

first_die++;if (first_die == 1 && mine[x][y] == "1")//first_die在test中創(chuàng)建,默認(rèn)傳遞0進(jìn)入		{			while (mine[x][y] == "1")			{				intialize(mine, ROWS, COLS, "0");//必須先初始化棋盤(pán),不然會(huì)導(dǎo)致原本的雷依然在				setmine(mine, ROW, COL);			}					}

6.雷數(shù)顯示

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

"0"的ASCII值為48,我們將雷設(shè)計(jì)為"1"就是為了方便相加以后減去8個(gè)"0",直接就可以得到雷的數(shù)量

7.排查雷

下面就是本文章的重點(diǎn)之一,雷的排查,其實(shí)實(shí)現(xiàn)思路也比較簡(jiǎn)單,如果踩到雷,游戲結(jié)束;如果沒(méi)有,繼續(xù)游戲,同時(shí)顯示附近雷的個(gè)數(shù)

	int x = 0;	int y = 0;			while (1)	{		printf("請(qǐng)輸入需要排查的坐標(biāo),如:1 1/n");		scanf("%d%d", &x, &y);		first_die++;				if (x >= 1 && x <= row && y >= 1 && y <= col)//判斷輸入的行列號(hào)是否在規(guī)定范圍		{			if (mine[x][y] == "1")			{				printf("你死了,請(qǐng)?jiān)俳釉賲?n");				print(mine, ROW, COL);				break;			}			else			{				show[x][y] = search_show(mine, ROW, COL)+"0";//顯示周?chē)睦讛?shù)				open(mine,show, x, y,row,col);				print(show, ROW, COL);							}		}		else		{			printf("輸入錯(cuò)誤,請(qǐng)重新輸入/n");		}

8.標(biāo)記雷

我們可以在排查以后加入一個(gè)標(biāo)記功能,我們規(guī)定用"#"標(biāo)記,同時(shí)只能標(biāo)記未知量

//標(biāo)記地雷		int input1 = 0;		int input2 = 0;		if (x >= 1 && x <= row && y >= 1 && y <= col)		{			do//至少要運(yùn)行一次			{				printf("請(qǐng)輸入標(biāo)記坐標(biāo),輸入0 0退出標(biāo)記/n");				scanf("%d%d", &input1, &input2);				if (input1 >= 1 && input1 <= row && input2 >= 1 && input2 <= col)				{					if (show[input1][input2] == "*")//只標(biāo)記未知量					{						show[input1][input2] = "#";						print(show, ROW, COL);					}					else					{						printf("標(biāo)記失敗,請(qǐng)重新標(biāo)記/n");					}				}				else if (input1 == 0 && input2 == 0)//輸入0 0退出標(biāo)記					break;				else				{					printf("標(biāo)記錯(cuò)誤,請(qǐng)重新標(biāo)記/n");				}			} while (input1&&input2);			printf("已退出標(biāo)記/n");		}

9.展開(kāi)

這應(yīng)該是最難實(shí)現(xiàn)的一部分,這里我們用到遞歸的思想

void open(char mine[ROWS][COLS],char show[ROWS][COLS], int x, int y,int row ,int col){	int ret = 0;	ret =search_show(mine,x,y);		if (ret == 0)//如果周?chē)鸁o(wú)雷,判斷展開(kāi)	{		show[x][y] = " ";//防止死遞歸,如果不將show[x][y]變?yōu)? ",則下一次檢測(cè)可能又會(huì)是*,再次進(jìn)入遞歸,直至卡死。		if (x - 1 > 0 && y > 0 && show[x - 1][y] == "*"|| show[x - 1][y] == "#")			open(mine, show, x - 1, y, row, col);		if (x - 1 > 0 && y + 1 <= col && show[x - 1][y + 1] == "*"|| show[x - 1][y + 1] == "#")			open(mine, show, x - 1, y + 1, row, col);		if (x > 0 && y + 1 <= col && show[x][y + 1] == "*"|| show[x][y + 1] == "#")			open(mine, show, x, y + 1, row, col);		if (x + 1 <= row && y + 1 <= col && show[x + 1][y + 1] == "*"|| show[x + 1][y + 1] == "#")			open(mine, show, x + 1, y + 1, row, col);		if (x + 1 <= row && y > 0 && show[x + 1][y] == "*"|| show[x + 1][y] == "#")			open(mine, show, x + 1, y, row, col);		if (x + 1 <= row && y - 1 > 0 && show[x + 1][y - 1] == "*"|| show[x + 1][y - 1] == "#")			open(mine, show, x + 1, y - 1, row, col);		if (x > 0 && y - 1 > 0 && show[x][y - 1] == "*"|| show[x][y - 1] == "#")			open(mine, show, x, y - 1, row, col);		if (x - 1 > 0 && y - 1 > 0 && show[x - 1][y - 1] == "*"|| show[x - 1][y - 1] == "#")			open(mine, show, x - 1, y - 1, row, col);			}	else//有雷則返回雷數(shù)	{		return show[x][y]=search_show(mine, x, y)+"0";	}}

10.難度設(shè)置

其實(shí)實(shí)現(xiàn)思路比較簡(jiǎn)單,可以再設(shè)置MIDDLE_COUNT和HARD_COUNT。

傳參時(shí),將難度數(shù)字也傳進(jìn)去即可

這里交給大家去自行實(shí)現(xiàn),不算難

11.全局代碼

game.h# define _CRT_SECURE_NO_WARNINGS#include #include #include #define ROW 9#define COL 9#define ROWS ROW+2#define COLS COL+2#define EASY_COUNT 10//初始化void intialize(char board[ROWS][COLS], int row, int col, char target);//打印棋盤(pán)void print(char board[ROWS][COLS], int row, int col);//布置雷void setmine(char board[ROWS][COLS], int row, int col);//排查雷void search(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col,intgame.c# define _CRT_SECURE_NO_WARNINGS# include "game.h"void intialize(char board[ROWS][COLS], int row, int col, char target){	int i = 0;	for (i = 0; i < row; i++)	{		int j = 0;		for (j = 0; j < col; j++)		{			board[i][j] = target;		}	}}void print(char board[ROWS][COLS], int row, int col){	int i = 0;	for (i = 0; i <= row; 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 ", board[i][j]);		}		printf("/n");	}}void setmine(char board[ROWS][COLS], int row, int col){	int x = 0;	int y = 0;	int count = 0;	while (1)	{		x = rand() % row + 1;		y = rand() % col + 1;		if (board[x][y] != "1")		{			board[x][y] = "1";			count++;		}		if (count == EASY_COUNT)			break;	}}int search_show(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 open(char mine[ROWS][COLS],char show[ROWS][COLS], int x, int y,int row ,int col){	int ret = 0;	ret =search_show(mine,x,y);		if (ret == 0)//如果周?chē)鸁o(wú)雷,判斷展開(kāi)	{		show[x][y] = " ";//防止死遞歸,如果不將show[x][y]變?yōu)? ",則下一次檢測(cè)可能又會(huì)是*,再次進(jìn)入遞歸,直至卡死。		if (x - 1 > 0 && y > 0 && show[x - 1][y] == "*"|| show[x - 1][y] == "#")			open(mine, show, x - 1, y, row, col);		if (x - 1 > 0 && y + 1 <= col && show[x - 1][y + 1] == "*"|| show[x - 1][y + 1] == "#")			open(mine, show, x - 1, y + 1, row, col);		if (x > 0 && y + 1 <= col && show[x][y + 1] == "*"|| show[x][y + 1] == "#")			open(mine, show, x, y + 1, row, col);		if (x + 1 <= row && y + 1 <= col && show[x + 1][y + 1] == "*"|| show[x + 1][y + 1] == "#")			open(mine, show, x + 1, y + 1, row, col);		if (x + 1 <= row && y > 0 && show[x + 1][y] == "*"|| show[x + 1][y] == "#")			open(mine, show, x + 1, y, row, col);		if (x + 1 <= row && y - 1 > 0 && show[x + 1][y - 1] == "*"|| show[x + 1][y - 1] == "#")			open(mine, show, x + 1, y - 1, row, col);		if (x > 0 && y - 1 > 0 && show[x][y - 1] == "*"|| show[x][y - 1] == "#")			open(mine, show, x, y - 1, row, col);		if (x - 1 > 0 && y - 1 > 0 && show[x - 1][y - 1] == "*"|| show[x - 1][y - 1] == "#")			open(mine, show, x - 1, y - 1, row, col);			}	else	{		return show[x][y]=search_show(mine, x, y)+"0";	}}int win(char show[ROWS][COLS], int row, int col){	int i = 0;	int j = 0;	int count = 0;	for (i = 1; i <= row; i++)	{		for (j = 1; j <= col; j++)		{			if (show[i][j] == "*"||show[i][j]=="#")				count++;		}	}	if (count == EASY_COUNT)		return 1;	else		return 0;}void search(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col, int first_die){	int x = 0;	int y = 0;			while (1)	{		printf("請(qǐng)輸入需要排查的坐標(biāo),如:1 1/n");		scanf("%d%d", &x, &y);		first_die++;				//防止第一次暴斃		if (first_die == 1 && mine[x][y] == "1")		{			while (mine[x][y] == "1")			{				intialize(mine, ROWS, COLS, "0");				setmine(mine, ROW, COL);			}					}		if (x >= 1 && x <= row && y >= 1 && y <= col)		{			if (mine[x][y] == "1")			{				printf("你死了,請(qǐng)?jiān)俳釉賲?n");				print(mine, ROW, COL);				break;			}			else			{				show[x][y] = search_show(mine, ROW, COL)+"0";//顯示周?chē)睦讛?shù)				open(mine,show, x, y,row,col);				print(show, ROW, COL);							}		}		else		{			printf("輸入錯(cuò)誤,請(qǐng)重新輸入/n");		}				//判斷輸贏		int Win = win(show, row, col);		if (Win == 1)		{			printf("恭喜您,勝利了/n");			break;		}		//標(biāo)記地雷		int input1 = 0;		int input2 = 0;		if (x >= 1 && x <= row && y >= 1 && y <= col)		{			do			{				printf("請(qǐng)輸入標(biāo)記坐標(biāo),輸入0 0退出標(biāo)記/n");				scanf("%d%d", &input1, &input2);				if (input1 >= 1 && input1 <= row && input2 >= 1 && input2 <= col)				{					if (show[input1][input2] == "*")					{						show[input1][input2] = "#";						print(show, ROW, COL);					}					else					{						printf("標(biāo)記失敗,請(qǐng)重新標(biāo)記/n");					}				}				else if (input1 == 0 && input2 == 0)					break;				else				{					printf("標(biāo)記錯(cuò)誤,請(qǐng)重新標(biāo)記/n");				}			} while (input1&&input2);			printf("已退出標(biāo)記/n");		}	}}test.c# define _CRT_SECURE_NO_WARNINGS# include "game.h"void menu(){	printf("*********************************/n");	printf("*********    1. Play    *********/n");	printf("*********    0. Exit    *********/n");	printf("*********************************/n");	}void game(){	char mine[ROWS][COLS] = { 0 };//存放雷的信息	char show[ROWS][COLS] = { 0 };//存放排查出的雷的信息	intialize(mine,ROWS ,COLS,"0");	intialize(show,ROWS ,COLS,"*");	//展示棋盤(pán)	print(show, ROW, COL);		//布置雷	setmine(mine, ROW, COL);		//排查	search(mine, show, ROW, COL,0);}int main(){	int input = 0;	srand((unsigned int)time(NULL));	do	{		menu();		printf("請(qǐng)選擇>:");		scanf("%d", &input);		switch (input)		{		case 1:			printf("game start/n");			game();			break;		case 0:			printf("已退出游戲/n");			break;		default:			printf("選擇錯(cuò)誤,請(qǐng)重新選擇/n");			break;		}	} while (input);	return 0;}

以上就是本次的分享內(nèi)容了,喜歡我的分享的話,別忘了點(diǎn)贊加關(guān)注喲!

如果你對(duì)我的文章有任何看法,歡迎在下方評(píng)論留言或者私信我鴨!

我是白晨,我們下次分享見(jiàn)?。?/strong>

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/121852.html

相關(guān)文章

  • C語(yǔ)言初階學(xué)習(xí)——掃雷游戲(遞歸)

    摘要:目錄前言前言前期的準(zhǔn)備前期的準(zhǔn)備游戲代碼的具體實(shí)現(xiàn)游戲代碼的具體實(shí)現(xiàn)完整版的掃雷小游戲代碼完整版的掃雷小游戲代碼總結(jié)總結(jié)前言掃雷是一款大眾類(lèi)的益智小游戲,于年發(fā)行。 目錄 前言 前期的準(zhǔn)備 游戲代碼的具體實(shí)現(xiàn) 1、text.c 2、game.h 3、game.c 完整版的掃雷小游戲代碼: 1...

    zhonghanwen 評(píng)論0 收藏0
  • C語(yǔ)言入門(mén)掃雷游戲C語(yǔ)言實(shí)現(xiàn)

    摘要:條消息語(yǔ)言入門(mén)三子棋語(yǔ)言實(shí)現(xiàn)詳細(xì)版的博客博客條消息語(yǔ)言入門(mén)三子棋語(yǔ)言實(shí)現(xiàn)詳細(xì)版的博客博客我們將雷盤(pán)初始化為統(tǒng)一的符號(hào)。 目錄 1.原理簡(jiǎn)介 2.分布目標(biāo)及代碼實(shí)現(xiàn) 3.總結(jié) 1.原理簡(jiǎn)介 ?首先我們需要一個(gè)空的雷盤(pán),在其中隨機(jī)埋入十枚雷,當(dāng)我們排這顆雷時(shí),若此位置為雷,則游戲失敗,若不...

    caige 評(píng)論0 收藏0
  • C語(yǔ)言實(shí)現(xiàn)【掃雷游戲】拓展版

    摘要:作者時(shí)間網(wǎng)站地址摘要語(yǔ)言實(shí)現(xiàn)我們小時(shí)候玩過(guò)的掃雷游戲,最近看到了一些掃雷游戲的簡(jiǎn)單實(shí)現(xiàn),但是總有功能上的缺失,玩起來(lái)不那么的原汁原味,因此我增加了一些新功能確保玩家首次排雷一定不會(huì)炸死。 ...

    JayChen 評(píng)論0 收藏0
  • C語(yǔ)言實(shí)現(xiàn)入門(mén)級(jí)小游戲——掃雷

    摘要:上一期咱們用語(yǔ)言實(shí)現(xiàn)了三子棋的小游戲語(yǔ)言實(shí)現(xiàn)三子棋今天我們?cè)賮?lái)寫(xiě)個(gè)掃雷的游戲,說(shuō)起掃雷,相信大家都不陌生,可能許多朋友還是玩掃雷的高手。 ? ? ?上一期咱們用C語(yǔ)言實(shí)現(xiàn)了三子棋的小游戲? C語(yǔ)言實(shí)現(xiàn)三子棋? ? ? ?今天我們?cè)賮?lái)寫(xiě)個(gè)掃雷的游戲,說(shuō)起掃雷,相信大家都不陌生,可能許多朋友還是...

    nevermind 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<