本篇內(nèi)容主要講解“C語言實現(xiàn)的掃雷游戲代碼分享”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“C語言實現(xiàn)的掃雷游戲代碼分享”吧!
成都創(chuàng)新互聯(lián)制作網(wǎng)站網(wǎng)頁找三站合一網(wǎng)站制作公司,專注于網(wǎng)頁設(shè)計,成都網(wǎng)站設(shè)計、網(wǎng)站制作,網(wǎng)站設(shè)計,企業(yè)網(wǎng)站搭建,網(wǎng)站開發(fā),建網(wǎng)站業(yè)務(wù),680元做網(wǎng)站,已為上千家服務(wù),成都創(chuàng)新互聯(lián)網(wǎng)站建設(shè)將一如既往的為我們的客戶提供最優(yōu)質(zhì)的網(wǎng)站建設(shè)、網(wǎng)絡(luò)營銷推廣服務(wù)!代碼如下:
#include<stdio.h>#include<stdlib.h>#include<time.h>#define MAX_ROW 9#define MAX_COL 9#define MINE_C0UNT 10void menu() { printf("************************\n"); printf("***** 1.play ****\n"); printf("***** 0.exit ****\n"); printf("************************\n");}//1、先初始化兩個地圖,玩家看到的,地雷布局圖。void Init(char show_map[MAX_ROW][MAX_COL],char mine_map[MAX_ROW][MAX_COL]) { //對于玩家看到的地圖,未翻到的都設(shè)為*; for (int row = 0; row < MAX_ROW; row++) { for (int col = 0; col < MAX_COL; col++) { show_map[row][col] = '*'; } } //對于地雷布局圖,用0表示沒有地雷,用1表示雷。 for (int row = 0; row < MAX_ROW; row++) { for (int col = 0; col < MAX_COL; col++) { mine_map[row][col] = '0'; } } //假設(shè)設(shè)置十個地雷 int n = MINE_C0UNT; while (n > 0) { int row = rand() % MAX_ROW; int col = rand() % MAX_COL; if (mine_map == '1') { continue; } mine_map[row][col] = '1'; --n; }}void printmap(char map[MAX_ROW][MAX_COL]) { //不光能打印出地圖,還能帶坐標(biāo)//先打印第一行 printf(" "); for (int i = 0; i < MAX_COL; i++) { printf("%d ", i); } printf("\n"); //打印一個分割線 for (int col = 0; col < MAX_COL - 2; ++col) { printf("---"); } printf("\n"); //在打印其他行 for (int row = 0; row < MAX_ROW; row++) { printf(" %d| ", row); //打印本行的每一列 for (int col = 0; col < MAX_COL; col++) { printf("%c ", map[row][col]); } printf("\n"); }}void updateshowmap(int row,int col,char show_map[MAX_ROW][MAX_COL], char mine_map[MAX_ROW][MAX_COL]) { int count = 0; if (row - 1 >= 0 && col - 1 >= 0 && row - 1 < MAX_ROW && col - 1 < MAX_COL && mine_map[row - 1][col - 1] == '1') { count++; } if (row - 1 >= 0 && col >= 0 && row - 1 < MAX_ROW && col < MAX_COL && mine_map[row - 1][col] == '1') { count++; } if (row - 1 >= 0 && col + 1 >= 0 && row - 1 < MAX_ROW && col + 1 < MAX_COL && mine_map[row - 1][col + 1] == '1') { count++; } if (row >= 0 && col - 1 >= 0 && row < MAX_ROW && col - 1 < MAX_COL && mine_map[row][col - 1] == '1') { count++; } if (row >= 0 && col + 1 >= 0 && row < MAX_ROW && col + 1 < MAX_COL && mine_map[row][col + 1] == '1') { count++; } if (row + 1 >= 0 && col - 1 >= 0 && row + 1 < MAX_ROW && col - 1 < MAX_COL && mine_map[row + 1][col - 1] == '1') { count++; } if (row + 1 >= 0 && col + 1 >= 0 && row + 1 < MAX_ROW && col + 1 < MAX_COL && mine_map[row + 1][col + 1] == '1') { count++; } show_map[row][col] = '0' + count;}void game() { char show_map[MAX_ROW][MAX_COL]; char mine_map[MAX_ROW][MAX_COL]; Init(show_map,mine_map); while (1) { printmap(show_map); printf("請玩家輸入一組坐標(biāo):"); int row, col; int blank_count_already_show = 0; scanf("%d%d", &row, &col); system("cls"); if (row < 0 || row >= MAX_ROW || col < 0 || col >= MAX_COL) { printf("您的輸入不合法,請您重新輸入!\n"); continue; } if (show_map[row][col] != '*') { printf("您輸入的位置已經(jīng)被占用了,請您重新輸入!\n"); continue; } //判斷玩家輸入的坐標(biāo)對應(yīng)的是不是地雷,如果是地雷則游戲就結(jié)束了 if (mine_map[row][col] == '1') { printf("游戲結(jié)束!\n"); printmap(mine_map); break; } //判斷游戲是否勝利,通過計算已翻開的非雷的格子的個數(shù) ++blank_count_already_show; if (blank_count_already_show == MAX_ROW * MAX_COL - MINE_C0UNT) { printf("游戲勝利 !\n"); printmap(mine_map); break; } //統(tǒng)計當(dāng)前位置中周圍雷的個數(shù) updateshowmap(row, col, show_map, mine_map); }}int main() { srand((unsigned)time(0)); int input = 0; while (1) { menu(); printf("請選擇:"); scanf("%d", &input); if (input == 1) { printf("開始游戲!\n"); game(); } else if (input == 0) { printf("退出游戲!\n"); break; } else { printf("輸入錯誤,請重新輸入!\n"); continue; } } system("pause"); return 0;}
到此,相信大家對“C語言實現(xiàn)的掃雷游戲代碼分享”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)建站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
本文標(biāo)題:C語言實現(xiàn)的掃雷游戲代碼分享-創(chuàng)新互聯(lián)
網(wǎng)頁網(wǎng)址:http://aaarwkj.com/article2/gdjoc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計、網(wǎng)站內(nèi)鏈、搜索引擎優(yōu)化、App設(shè)計、企業(yè)建站、網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容