網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
設(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é)
原文鏈接:https://blog.csdn.net/weixin_49326024/article/details/122542981
相關(guān)推薦
- 2022-03-17 初學(xué)Android之網(wǎng)絡(luò)封裝實(shí)例_Android
- 2022-05-27 hive中的幾種join到底有什么區(qū)別_數(shù)據(jù)庫(kù)其它
- 2021-12-06 c#二叉樹(shù)存儲(chǔ)介紹_C#教程
- 2023-04-06 分布式系統(tǒng)CAP定理中的P原理解析_相關(guān)技巧
- 2023-10-11 小程序|頁(yè)面?zhèn)鲄⒌娜N方式
- 2022-07-26 Python文件系統(tǒng)模塊pathlib庫(kù)_python
- 2022-03-20 C++?Qt繪制時(shí)鐘界面_C 語(yǔ)言
- 2023-11-12 解決yolov3編譯中出現(xiàn)的問(wèn)題:darknet make include/darknet.h:16
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門(mén)
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支