這篇文章給大家分享的是有關如何使用C語言實現(xiàn)掃雷游戲的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
目前創(chuàng)新互聯(lián)建站已為數(shù)千家的企業(yè)提供了網(wǎng)站建設、域名、雅安服務器托管、網(wǎng)站托管、服務器托管、企業(yè)網(wǎng)站設計、靖邊網(wǎng)站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
這是一個用C語言實現(xiàn)的控制臺掃雷小游戲,實現(xiàn)了隨機布置炸彈、掃描炸彈、標記炸彈、百分百第一次不被炸死等功能。
編譯器:vs2015
功能模塊圖
源代碼
#include<stdio.h> #include<stdlib.h> #include<time.h> void show(int cbd[10][10],int u[10][10]) //界面輸出函數(shù) { int i, j; //for (i = 0; i < 10; i++) //輸出全部炸彈信息(上帝視角,調(diào)試用) //{ // for (j = 0; j < 10; j++) // { // printf("%2d ", cbd[i][j]); // } // printf("\n"); //} printf(" 1 2 3 4 5 6 7 8 9 10\n"); //行標 printf(" --------------------\n"); for (i = 0; i<10; i++) //根據(jù)u數(shù)組和cbd數(shù)組的值選擇輸出 { //■:未掃描,□:周圍無炸彈,◇:炸彈標記 for (j = 0; j<10; j++) { if (j == 0)printf("%2d║ ", i+1); if (u[i][j] == 0)printf("■"); else if (u[i][j] == 1) { if (cbd[i][j] == 0)printf("□"); else printf("%2d", cbd[i][j]); } else if (u[i][j] == -1) { printf("◇"); } } printf("\n"); } } int find(int cbd[10][10], int i, int j) //掃描周圍炸彈數(shù)目 { int l, c,lmin,cmin, lmax, cmax, num = 0; l = lmin = (i - 1) >= 0 ? (i - 1) : 0; //計算行、列起點 c = cmin = (j - 1) >= 0 ? (j - 1) : 0; lmax = ((i + 1) < 10 ? (i + 1) : 9); //計算行、列終點 cmax = ((j + 1) < 10 ? (j + 1) : 9); for (l = lmin; l <= lmax; l++) { for (c = cmin; c <= cmax; c++) { if (l == i&&c == j)continue; //跳過自身 if (cbd[l][c] == -1)num++; //炸彈計數(shù) } } return num; } void init(int cbd[10][10]) //cbd數(shù)組初始化(隨機布置炸彈并填充各個格子的數(shù)目) { int n = 10, l, c, i, j; srand(time(NULL)); //隨機數(shù)種子設置 for (i = 0; i< 10; i++) { for (j = 0; j< 10; j++) { cbd[i][j] = 0; //全0填充 } } while (n--) //隨機行列放置炸彈 { l = rand() % 10; c = rand() % 10; if (cbd[l][c] != -1)cbd[l][c] = -1; //炸彈重復處理 else n++; } for (i = 0; i< 10; i++) { for (j = 0; j< 10; j++) { if (cbd[i][j] != -1) { cbd[i][j] = find(cbd, i, j); //炸彈數(shù)目填充 } } } } void open(int cbd[10][10],int u[10][10], int i, int j) //周圍無炸彈時的展開函數(shù)(遞歸展開) { u[i][j] = 1; if (cbd[i][j] == 0) { if(i - 1 >= 0 && u[i - 1][j] != 1)open(cbd, u, i - 1, j); //上 if(j - 1 >= 0 && u[i][j - 1] != 1)open(cbd, u, i, j - 1); //左 if (i + 1 <= 9 && u[i + 1][j] != 1)open(cbd, u, i + 1, j); //下 if (j + 1 <= 9 && u[i][j + 1] != 1)open(cbd, u, i, j + 1); //右 } } int judge(int u[10][10]) //判斷游戲是否通關 { int i, j, num = 0; for (i = 0; i < 10; i++) { for (j = 0; j < 10; j++) { if (u[i][j] == 0 || u[i][j] == -1)num++; } } if (num == 10)return 1; else return 0; } void fail(int cbd[10][10], int u[10][10]) //游戲失敗函數(shù) { int i, j; for (i = 0; i < 10; i++) //輸出全部炸彈信息 { for (j = 0; j < 10; j++) { if (cbd[i][j] == 0)printf(" "); else if (cbd[i][j] != -1)printf("%2d", cbd[i][j]); else printf("●"); } printf("\n"); } printf("請大俠重新來過~\n"); } void menu(int cbd[10][10],int u[10][10]) //菜單函數(shù) { int chs,i,j; int boom = 10; //剩余炸彈數(shù) int num = 0; //步數(shù) while (1) { system("cls"); show(cbd,u); printf("還有%d個炸彈\n",boom); printf("1.掃描 2.標記 3.取消標記\n"); printf("請輸入選項:>"); scanf("%d", &chs); if (chs > 3 || chs < 1) { printf("請輸入正確選項!\n"); system("pause"); continue; } printf("請輸入坐標:>"); scanf("%d %d", &i, &j); if (i < 1 || i>10) { printf("請輸入正確坐標!\n"); system("pause"); continue; } i--; //輸入行列數(shù)處理(適用數(shù)組下標) j--; if (chs == 1) { if (cbd[i][j] == -1) { if (num == 0) { //若第一步掃描到炸彈,就重新初始化棋盤 init(cbd); show(cbd, u); open(cbd, u, i, j); num++; continue; } else { fail(cbd, u); //否則游戲失敗,循環(huán)跳出 break; } } if (u[i][j] == 1) //重復掃描時的處理 { printf("該位置已經(jīng)掃描過了!\n"); system("pause"); continue; } open(cbd, u, i, j); num++; } else if(chs == 2) { if (u[i][j] == 1) { printf("該位置已經(jīng)掃描過了!\n"); //只能標記未掃描到的 system("pause"); continue; } u[i][j] = -1; boom --; } else if (chs == 3) { if (u[i][j] != -1) { printf("該位置沒有標記!\n"); //只能取消標記過的 system("pause"); continue; } u[i][j] = 0; boom++; } if (judge(u)) //判斷游戲是否通關 { printf("Old Fe 666!\n"); //老鐵666!,循環(huán)跳出 break; } } } int main() { int cbd[10][10] = { 0 }; //保存炸彈信息的二維數(shù)組 int u[10][10] = { 0 }; //保存是否翻開信息的二維數(shù)組 init(cbd); //數(shù)組初始化 menu(cbd, u); //進入菜單 return 0; }
Tips:在掃描到周圍無炸彈的格子時,要將此格子周圍的部分依次打開,直到上下左右都出現(xiàn)炸彈數(shù)字為止,這里要用到遞歸的方法,我的順序為依次遞歸處理上、左、下、右的格子,這里順序可以任意。
C語言是一門面向過程的、抽象化的通用程序設計語言,廣泛應用于底層開發(fā),使用C語言可以以簡易的方式編譯、處理低級存儲器。
感謝各位的閱讀!關于“如何使用C語言實現(xiàn)掃雷游戲”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
當前標題:如何使用C語言實現(xiàn)掃雷游戲
網(wǎng)址分享:http://muchs.cn/article10/gjsego.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導航、小程序開發(fā)、網(wǎng)站維護、網(wǎng)頁設計公司、移動網(wǎng)站建設、ChatGPT
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)