亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語言開發(fā)實現掃雷游戲

 更新時間:2020年11月12日 08:45:32   作者:F....  
這篇文章主要為大家詳細介紹了C語言開發(fā)實現掃雷游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了C語言實現掃雷游戲的具體代碼,供大家參考,具體內容如下

簡單描述:

輸入要要掃的位置.
如果是雷,則游戲失敗.
如果將所有不是雷的位置都掃了一遍,則游戲勝利.

主要細節(jié)

1、初始化(玩家掃雷圖,地雷布局圖)

展示出來的地圖(玩家能看到的地圖)showMap

for (int row = 0; row < ROW; row++){

 for (int col = 0; col < COL; col++){
 showMap[row][col] = '*';
 }
}

地雷的布局地圖(玩家看不到的地圖)mineMap

for (int row = 0; row < ROW; row++){

 for (int col = 0; col < COL; col++){
 mineMap[row][col] = '*';
 }
 }
 int count = 0;
 while (count<MINECOUNT){
 int row = rand() % 9;
 int col = rand() % 9;
 mineMap[row][col] = 'L';
 count++;
 }
}

3、打印地圖

void print(char Map[ROW][COL]){
 printf(" |0|1|2|3|4|5|6|7|8|\n");
 for (int row = 0; row < ROW; row++){
 printf("%d |", row);
 for (int col = 0; col < COL; col++){
 printf("%c ", Map[row][col]);
 }
 printf("\n");
 }
}

5、玩家輸入要掃的位置信息(9*9格子中某一特定位置)

void Input(char showMap[ROW][COL], char mineMap[ROW][COL], int* row, int* col){
 while (1){
 printf("請輸入您要點的位置坐標:");
 scanf("%d %d", row, col);
 if (((*row) < 0) || ((*row) >= ROW)
 || ((*col) < 0) || ((*col) >= COL)){
 printf("輸入有誤 ");
 continue;
 }
 if (showMap[*row][*col] == '*'){
 showMap[*row][*col] = ' ';
 break;
 }
 }
}

7、判斷某一位置是不是地雷

//返回1表示雷;返回0表示不是雷
int isMine(char mineMap[ROW][COL], int row, int col){
 if (mineMap[row][col] == 'L'){
 return 1;
 }
 return 0;
}

9、某一位置附近地雷的個數

int MineNerborhood(char mineMap[ROW][COL], int row, int col){
 if (row < 0 || row >= ROW
 || col < 0 || col >= COL){
 return '0';
 }
 int count = 0;
 for (int r = row - 1; r <= row + 1; r++){
 for (int c = col - 1; c <= col + 1; c++){
 if (mineMap[r][c] == 'L'){
 count++;
 }
 }
 }
 return count + '0';
}

源代碼:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#define ROW 9
#define COL 9
#define MINECOUNT 10

void Input(char showMap[ROW][COL], char mineMap[ROW][COL], int* row, int* col){
 while (1){
 printf("請輸入您要點的位置坐標:");
 scanf("%d %d", row, col);
 if (((*row) < 0) || ((*row) >= ROW)
 || ((*col) < 0) || ((*col) >= COL)){
 printf("輸入有誤 ");
 continue;
 }
 if (showMap[*row][*col] == '*'){
 showMap[*row][*col] = ' ';
 break;
 }
 }
}

//返回1表示雷;返回0表示不是雷
int isMine(char mineMap[ROW][COL], int row, int col){
 if (mineMap[row][col] == 'L'){
 return 1;
 }
 return 0;
}
//
void init(char showMap[ROW][COL], char mineMap[ROW][COL]){

 for (int row = 0; row < ROW; row++){

 for (int col = 0; col < COL; col++){
 showMap[row][col] = '*';
 }
 }
 for (int row = 0; row < ROW; row++){

 for (int col = 0; col < COL; col++){
 mineMap[row][col] = '*';
 }
 }
 int count = 0;
 while (count<MINECOUNT){
 int row = rand() % 9;
 int col = rand() % 9;
 mineMap[row][col] = 'L';
 count++;
 }
}
void print(char Map[ROW][COL]){
 printf(" |0|1|2|3|4|5|6|7|8|\n");
 for (int row = 0; row < ROW; row++){
 printf("%d |", row);
 for (int col = 0; col < COL; col++){
 printf("%c ", Map[row][col]);
 }
 printf("\n");
 }
}
//(row,col)附近格子地雷的個數
int MineNerborhood(char mineMap[ROW][COL], int row, int col){
 if (row < 0 || row >= ROW
 || col < 0 || col >= COL){
 return '0';
 }
 int count = 0;
 for (int r = row - 1; r <= row + 1; r++){
 for (int c = col - 1; c <= col + 1; c++){
 if (mineMap[r][c] == 'L'){
 count++;
 }
 }
 }
 return count + '0';
}
//一局游戲
void game(){
 srand(time(0));
 //展示給玩家的地圖
 char showMap[ROW][COL];
 //雷的布局圖
 char mineMap[ROW][COL];
 //對兩個地圖進行初始化
 init(showMap, mineMap);
 //print(mineMap);
 //玩家已經掃到的不是雷的格子的數目
 int notMineCount = 0;
 printf("掃雷游戲開始啦!\n");
 while (1){
 //打印地圖
 print(showMap);
 //輸入地點
 int row, col;
 Input(showMap, mineMap, &row, &col);
 //判斷是否是雷區(qū)
 if (isMine(mineMap, row, col) == 1){
 printf(" 大兄弟,踩雷咧!\n給您看看雷的布局\n");
 print(mineMap);
 break;
 }
 //判斷附近雷的情況
 showMap[row][col]=MineNerborhood(mineMap, row, col);

 notMineCount++;
 //判斷是否贏了
 if (notMineCount == ROW*COL - MINECOUNT){
 print(mineMap);
 printf("恭喜您贏啦!\n");
 break;
 }
 }
 
}
int menu(){
 printf("===================\n");
 printf("1.開始游戲\n");
 printf("0.結束游戲\n");
 printf("===================\n");
 printf("請輸入您的選擇:");
 int choice;
 scanf("%d", &choice);
 return choice;
}
int main(){
 while (1){
 int choice = menu();
 if (choice == 1){
 game();
 }else if (choice==0){
 break;
 }else{
 printf("輸入有誤,請重新輸入\n");
 }
 }
 system("pause");
 return 0;
}

運行結果:



更多有趣的經典小游戲實現專題,分享給大家:

C++經典小游戲匯總

python經典小游戲匯總

python俄羅斯方塊游戲集合

JavaScript經典游戲 玩不停

java經典小游戲匯總

javascript經典小游戲匯總

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • C語言變長數組 struct中char data[0]的用法詳解

    C語言變長數組 struct中char data[0]的用法詳解

    下面小編就為大家?guī)硪黄狢語言變長數組 struct中char data[0]的用法詳解。小編覺得挺不錯的現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • C++內存對象布局小測試

    C++內存對象布局小測試

    這篇文章主要介紹了C++內存對象布局小測試,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • C++超詳細講解函數重載

    C++超詳細講解函數重載

    C++ 允許多個函數擁有相同的名字,只要它們的參數列表不同就可以,這就是函數的重載(Function Overloading),借助重載,一個函數名可以有多種用途
    2022-05-05
  • Qt中關聯容器QMap,QMultiMap,QHash,QMultiHash的使用

    Qt中關聯容器QMap,QMultiMap,QHash,QMultiHash的使用

    本文主要介紹了Qt中關聯容器QMap,QMultiMap,QHash,QMultiHash的使用,這些關聯容器在Qt中提供了靈活而強大的數據結構選項,根據具體的需求和使用場景,您可以選擇適合的容器來存儲和管理數據,感興趣的可以了解一下
    2023-09-09
  • C語言FlappyBird飛揚的小鳥實現開發(fā)流程

    C語言FlappyBird飛揚的小鳥實現開發(fā)流程

    因為在家宅了好多天,隨手玩了下自己以前做的一些小游戲,說真的,有幾個游戲做的是真的劣質,譬如 flappybird 真的讓我難以忍受,于是重做了一波分享給大家
    2022-11-11
  • C語言與C++中內存管理詳解

    C語言與C++中內存管理詳解

    本章主要介紹C語言與C++的內存管理,以C++的內存分布作為引入,介紹C++不同于C語言的內存管理方式(new?delete對比?malloc?free),感興趣的朋友來看看吧
    2022-04-04
  • static關鍵字的作用詳解

    static關鍵字的作用詳解

    在C語言中,static的字面意思很容易把我們導入歧途,其實它的作用有三條。
    2013-04-04
  • C語言實現一個文件版動態(tài)通訊錄流程詳解

    C語言實現一個文件版動態(tài)通訊錄流程詳解

    這篇文章主要介紹了C語言實現一個文件版動態(tài)通訊錄流程,希望大家能從這篇文章中收獲到許多,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2023-01-01
  • C++?數據結構超詳細講解單鏈表

    C++?數據結構超詳細講解單鏈表

    這篇文章主要介紹了C++數據結構之單鏈表,鏈表是由一個個結點鏈結成的。結點包括數據域和指針域兩部分,數據域用來存儲數據元素的信息,指針域用來存儲下一個結點的地址,更詳細內容請需要的小伙伴參考下面文章內容
    2022-03-03
  • 深入解析C++中的std::thread的使用

    深入解析C++中的std::thread的使用

    這篇文章主要介紹了C++中的std::thread的使用,在C++11新標準中,可以簡單通過使用thread庫,來管理多線程,本文通過實例代碼給大家詳細講解,需要的朋友可以參考下
    2023-04-04

最新評論