亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么用C語言實現掃雷經典游戲

發布時間:2021-07-30 14:32:14 來源:億速云 閱讀:172 作者:chen 欄目:開發技術

本篇內容介紹了“怎么用C語言實現掃雷經典游戲”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

C語言實現掃雷游戲,供大家參考,具體內容如下

實現掃雷游戲

與三子棋游戲類似,為了便于后期對于代碼的閱讀、理解與地圖大小和地雷的數量變更,先用#define定義一個標識符表示一個常量 (地圖的大小、地雷的個數等)

#define MAX_ROW 9
#define MAX_COL 9
#define mineNumber 10

游戲創建流程

1. 創建地圖

在這里,showMap表示向玩家展示的地圖,mineMap表示存放地雷的地圖(不向玩家展示,用于后期判斷玩家是否踩雷以及玩家所選擇位置周圍有多少地雷)。

char showMap[MAX_ROW][MAX_COL] = { 0 };
char mineMap[MAX_ROW][MAX_COL] = { 0 };

2. 地圖初始化

如代碼內容所示,這里使用到了memset,將一段內存上的每個字節都設置成一個具體的值。

void init(char showMap[MAX_ROW][MAX_COL],
    char mineMap[MAX_ROW][MAX_COL]) {
 //將showMap初始化為 '*'
  //普通寫法(循環)
   /*for (int row = 0; row < MAX_ROW; row++) {
    for (int col = 0; col < MAX_COL; col++) {
     showMap[row][col] = '*';
    }
   }*/

 //簡單寫法(memset函數,需要添加頭文件 string.h)
 //memset:將一段內存上的每個字節都設置成一個具體的值
 //memset('需要初始化的內存名稱', '初始化的內容', '初始化的容量大小')
 memset(showMap, '*', MAX_ROW*MAX_COL);
 memset(mineMap, '0', MAX_ROW*MAX_COL);
 //使用時間戳,產生隨機種子
 srand((unsigned int)time(0));
 int mineCount = 0;     //當前地雷的數量
 while (mineCount < mineNumber) {
  //將產生地雷的位置控制在地圖范圍內
  int row = rand() % MAX_ROW; 
  int col = rand() % MAX_COL;
  //判斷隨機選擇的位置是否已有地雷
  if (mineMap[row][col] == '1') {
   continue;
  }
  mineMap[row][col] = '1';
  //記錄地雷的數量
  mineCount++;
 }
}

3. 打印地圖

void print(char theMap[MAX_ROW][MAX_COL]) {
 for (int row = 0; row < MAX_ROW; row++) {
  for (int col = 0; col < MAX_COL; col++) {
   printf("%c", theMap[row][col]);
  }
  printf("\n");
 }
}

4. 玩家選擇需要翻開的位置

這一環節中:

(1)玩家輸入想翻開的位置(row col);
(2)進行合法性判定:判斷玩家輸入的坐標是否符合規范;
(3)判斷當前位置是否已經被翻開了;
(4)判斷當前位置是否有雷:即判定玩家是否出局。

 //玩家輸入坐標,表示想翻開的位置
 int row = 0;
 int col = 0;
 printf("請玩家輸入坐標(row col):");
 scanf("%d %d", &row, &col);
 
 //合法性判定
 if (row < 0 || row >= MAX_ROW || col < 0 || col >= MAX_COL) {
  printf("輸入錯誤,請重新輸入:\n");
  continue;
 }
 
 //判斷當前位置是否已被翻開(未翻開是'*')
 if (showMap[row][col] != '*') {
  printf("當前位置已被選擇,請重新輸入!\n");
  continue;
 }

 //判定當前位置是否有雷
 if (mineMap[row][col] == '1') {
  printf("踩雷,游戲結束!");
  break;
 }

5. 更新地圖

在這里,我們需要根據玩家輸入的內容更新地圖(showMap),包括:

(1)計算周圍地雷的數量

怎么用C語言實現掃雷經典游戲

如上圖所示,中心位置(row, col)是玩家所選擇的位置,周圍的位置可以如上圖所示表示它們的坐標。因為需要統計周圍有多少地雷的個數,所以可以通過循環,來判斷周圍的位置所存放的內容。
此外,在循環過程中,需要注意坐標不能越界,不能超過這3*3的范圍。(中間玩家的位置需要跳過)。

//更新地圖showMap,被翻開的置0并顯示被選擇的位置,周圍有多少地雷
void update(char showMap[MAX_ROW][MAX_COL], 
     char mineMap[MAX_ROW][MAX_COL], int row, int col) {
 //被選擇位置周圍的地雷數量
 int count = 0;
 for (int r = row - 1; r <= row + 1; r++) {
  for (int c = col - 1; c <= col + 1; c++) {
   //判斷循環的位置是否超出范圍
   if (r < 0 || r >= MAX_ROW || c < 0 || c >= MAX_COL) {
    continue;
   }
   //中間玩家選擇的位置跳過
   if (r == row && c == col) {
    continue;
   }
   //當位置的字符為'1'時,地雷數量+1
   if (mineMap[r][c] == '1') {
    count++;
   }
  }
 }
 //showMap[row][col]是char類型,count是int類型,不能直接賦值
 //在C語言中,可以用以下的方式進行字符賦值
 //'0'在ASCII中的十進制數為48,之后繼續是字符'1','2'...
 //所以通過以下方式,將周圍的地雷數量賦值給玩家選擇的位置
 showMap[row][col] = '0' + count;
}

最后這句showMap[row][col] = '0' + count;需要注意。

由于我們的目的是將周圍地雷的數量賦值給玩家所選擇的位置(row, col),所以我們需要考慮他們之間的關聯性。
(row, col)是char型,count是int型,肯定是不能直接賦值的,但是在C語言中,我們可以通過上邊寫到的方式將值賦給(row, col)。
在ASCII中,'0'的十進制數是48,‘0'之后一次是字符型的'1', ‘2',…,所以我們是將字符1, 2, …賦值給了(row, col)

怎么用C語言實現掃雷經典游戲

(注:這種賦值方式,只能在C語言中,其他的語言是不可以的)

6. 判定勝負

判斷玩家是否已經翻開所有位置:

(1)已翻開所有位置:判定勝利,程序結束;
(2)未完全翻開所有位置:循環環節2-6.

//openedCount是用來計算已經翻開位置的數量。
if (openedCount == MAX_ROW * MAX_COL - mineNumber) {
   printf("已翻開所有位置,恭喜玩家勝利!");
   break;
  }

“怎么用C語言實現掃雷經典游戲”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

滦南县| 电白县| 沈丘县| 嵩明县| 临泽县| 慈利县| 潞城市| 日喀则市| 安丘市| 中方县| 容城县| 和田县| 贵溪市| 蓝山县| 天峻县| 融水| 松江区| 舟山市| 武宣县| 武陟县| 大竹县| 常德市| 邻水| 建始县| 常山县| 巴林左旗| 平谷区| 和政县| 肇庆市| 河北区| 保山市| 余姚市| 子洲县| 汝州市| 汽车| 阳朔县| 正定县| 定边县| 绥滨县| 广水市| 康定县|