用C語(yǔ)言實(shí)現(xiàn)排雷游戲
設(shè)計(jì)簡(jiǎn)單的游戲界面菜單
輸入數(shù)字1,進(jìn)入游戲;
輸入數(shù)字0,退出游戲;輸入其他數(shù)字,將顯示輸入錯(cuò)誤,重新輸入;
排雷過(guò)程
輸入坐標(biāo),將顯示是否排到雷,或者沒(méi)有。
顯示的數(shù)字,將是該坐標(biāo)周?chē)藗€(gè)坐標(biāo)總共有幾個(gè)雷。(如圖,則有3顆)。如果輸入的坐標(biāo)超出坐標(biāo)范圍,將會(huì)提示,坐標(biāo)非法輸入,重新輸入。
如果你輸入的坐標(biāo)有雷,將會(huì)出現(xiàn),你被炸,游戲結(jié)束!
如果排雷成功,將顯示你成功排雷。(這里設(shè)置了雷數(shù)是80個(gè),將直接操作顯示出來(lái))。
相應(yīng)的代碼
測(cè)試代碼在------text.c
#include"game.h"
void menu() { printf("****************\n"); printf(" 1. PLAY *\n"); printf(" 0. EXIT ******\n"); printf("*******************\n"); } void game() { //雷的信息; //1.布置雷的信息; char mine[ROWS][COLS]={0};//1111 //2.排查雷 char show[ROWS][COLS]={0}; //初始化; InitBoard(mine,ROWS,COLS,‘0'); InitBoard(show,ROWS,COLS,''); //打印棋盤(pán); //DisplayBoard(mine,ROW,COL); DisplayBoard(show,ROW,COL); //布置雷; SetMine(mine,ROW,COL); DisplayBoard(mine,ROW,COL); //掃雷; FindMine(mine,show,ROW,COL); } void test() { int input = 0; srand((unsigned int)time(NULL)); do { menu(); printf(“請(qǐng)選擇:>\n”); scanf("%d",&input); switch(input) { case 1: game(); break; case 0: printf(“退出游戲\n”); break; default: printf(“選擇錯(cuò)誤,請(qǐng)重新選擇!\n”); break; } } while(input); } int main() { test(); return 0; } 2. 函數(shù)的聲明 #define ROW 9 //顯示時(shí)棋盤(pán)的行數(shù); #define COL 9 //顯示時(shí)棋盤(pán)的列數(shù); #define ROWS ROW+2 #define COLS COL+2 #define EASY_COUNT 10 //雷的總數(shù); #include <stdio.h> #include <stdlib.h> #include <time.h> void InitBoard(char board[ROWS][COLS],int rows,int cols,int set); void DisplayBoard(char board[ROW][COLS],int row,int col); void SetMine(char board[ROWS][COLS],int row,int col); void FindMine(char mine[ROWS][COLS],char show[ROWS][COLS],int row,int col); 3. 相關(guān)函數(shù)的定義 #include “game.h” void InitBoard(char board[ROWS][COLS],int rows,int cols,int 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[ROW][COLS],int row,int col) { int i = 0; int j = 0; //打印列號(hào); for( i =0;i<=col;i++) { printf("%d “,i); } printf(”\n"); for(i = 1;i<=row;i++) { printf("%d “,i);//行號(hào) 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 = EASY_COUNT; while(count) { int x = rand()%row+1; int y = rand()%col+1; if(board[x][y]==‘0') { board[x][y]=‘1'; count–; } } } 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; while(win<rowcol-EASY_COUNT) { printf(“請(qǐng)輸入坐標(biāo):>\n”); 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//計(jì)算雷的個(gè)數(shù); { int count = get_mine_count(mine,x,y); show[x][y]=count+‘0'; DisplayBoard(show,ROW,COL); win++; } } else { printf(“輸入非法坐標(biāo),請(qǐng)重新輸入\n”); } } if(winrowcol-EASY_COUNT) { printf(“恭喜你,排雷成功\n”); DisplayBoard(mine,ROW,COL); } }
一級(jí)目錄排雷游戲的缺陷與不足
設(shè)計(jì)排雷游戲非常的簡(jiǎn)易,而且對(duì)于輸入坐標(biāo)只能一個(gè)一個(gè)排,并不能在一定的情況下,將不是雷的空位顯示出來(lái),所以排雷過(guò)程中需要花費(fèi)大量的時(shí)間。設(shè)計(jì)上面并不是很美觀,只能是簡(jiǎn)易的游戲!
一級(jí)目錄改進(jìn)
需要運(yùn)用遞歸去改進(jìn)排雷游戲中關(guān)鍵的一步!
總結(jié)
到此這篇關(guān)于用C語(yǔ)言實(shí)現(xiàn)排雷游戲的文章就介紹到這了,更多相關(guān)C語(yǔ)言排雷游戲內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++ OpenCV實(shí)戰(zhàn)之圖像全景拼接
本文主要介紹了如何使用OpenCV C++ 進(jìn)行圖像全景拼接,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)OpenCV有一定的幫助,感興趣的可以了解一下2022-01-01Qt數(shù)據(jù)庫(kù)應(yīng)用之實(shí)現(xiàn)通用數(shù)據(jù)庫(kù)清理
項(xiàng)目如果需要存儲(chǔ)很多日志記錄比如運(yùn)行日志,時(shí)間長(zhǎng)了記錄數(shù)量非常多,數(shù)據(jù)庫(kù)體積不斷增大,對(duì)應(yīng)數(shù)據(jù)庫(kù)表的增刪改查的效率不斷降低,因此需要將早期的數(shù)據(jù)清理。本文將詳細(xì)介紹一下通用數(shù)據(jù)庫(kù)清理的實(shí)現(xiàn),需要的可以參考一下2022-02-02C++實(shí)現(xiàn)保存數(shù)據(jù)至EXCEL
這篇文章主要介紹了C++實(shí)現(xiàn)保存數(shù)據(jù)至EXCEL,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11OpenCV實(shí)現(xiàn)彩色照片轉(zhuǎn)換成素描卡通片
這篇文章主要為大家詳細(xì)介紹了OpenCV實(shí)現(xiàn)彩色照片轉(zhuǎn)換成素描卡通片,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01C++ xxx_cast實(shí)現(xiàn)轉(zhuǎn)換代碼實(shí)例解析
這篇文章主要介紹了C++xxx_cast轉(zhuǎn)換代碼實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07C語(yǔ)言實(shí)現(xiàn)隨機(jī)搶紅包功能
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)隨機(jī)搶紅包功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07C++從匯編的視角審視對(duì)象的創(chuàng)建問(wèn)題
這篇文章主要介紹了C++從匯編的視角看對(duì)象的創(chuàng)建,從匯編的視角來(lái)看,調(diào)用構(gòu)造器和調(diào)用 “返回對(duì)象” 的函數(shù)是一樣的,從匯編的角度來(lái)看,對(duì)象就是一堆數(shù)據(jù)的排列,比如說(shuō)最普通的對(duì)象就是數(shù)據(jù)成員按照聲明順序直接排列,需要的朋友可以參考下2022-01-01C語(yǔ)言實(shí)現(xiàn)會(huì)員計(jì)費(fèi)系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)會(huì)員計(jì)費(fèi)系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05