C語言二維數組應用實現掃雷遊戲

本文實例為大傢分享瞭C語言二維數組應用實現掃雷遊戲的具體代碼,供大傢參考,具體內容如下

遊戲簡介:

電腦隨機設置10個雷,用戶輸入坐標,若坐標下是雷則結束遊戲,不是則該位置顯示周圍的雷數。

game.h

#ifndef __GAME_H__ 
#define __GAME_H__ 
#include<stdio.h> 
//設置屏幕顯示的雷盤的大小
#define ROW 9 
#define COL 9 

//設置實際雷盤的大小(判斷雷數是看用戶所選的坐標周圍八個坐標內是否設雷,但若是用戶選擇的坐標是位於雷盤四周,則會數組訪問越界,所以行和列都要多設兩行)
#define ROWS ROW+2 
#define COLS COL+2 

//設置雷的數量
#define MINE_NUM 10 

#include<stdlib.h> 
#include<time.h> 
//初始化雷盤 
void IntiBoard(char board[][ROWS], int row, int col, char set);
//打印雷盤
void Show(char board[][ROWS], int row, int col);
//設置雷的位置
void SetMine(char board[][ROWS], int row, int col);
//找雷
void FindMine(char Mine[][ROWS], char MineInfo[][ROWS], int row, int col);
#endif

test.c

#define _CRT_SECURE_NO_WARNINGS 1 
#include"game.h" 
//遊戲菜單打印
void menu()
{ 
    printf("********0.exit********\n");
    printf("********1.play********\n");
    printf("**********************\n");
}
//進入遊戲
void game()
{
    char Mine[ROWS][COLS] = { 0 };//後臺設置雷的情況
    IntiBoard(Mine, ROWS, ROWS,'0');//0為未設雷,1為設雷,先置為全0

    char MineInfo[ROWS][COLS] = { 0 };//用來展示給用戶看的雷盤
    IntiBoard(MineInfo, ROWS, ROWS, '*');//將該雷盤全置為*
    Show(MineInfo, ROWS, ROWS);//打印雷盤

    SetMine(Mine, ROW, ROW);//設置雷

    FindMine(Mine,MineInfo, ROW, ROW);//用戶找雷
}

int main()
{
    int input = 0;
    do
    {
        menu();
        printf("請輸入您的選擇-->");
        scanf("%d", &input);
        switch (input)
        {
        case 1:
            printf("遊戲開始,玩的開心呦~~~\n");
            game();//進入遊戲
            break;
        case 0:
            printf("遊戲退出\n");
            break;
        default:
            printf("請輸入正確的操作");
            break;
        }
    } while (input);//循環至少執行一次
    return 0;
}

game.c

#define _CRT_SECURE_NO_WARNINGS 1
#include"game.h"
//將雷盤元素重置為char set
void IntiBoard(char board[][ROWS], int row, int col, char set)
{
    int i = 0;
    int j = 0;
    //遍歷數組
    for (i = 0; i < row; i++)
    {
        for (j = 0; j < col; j++)
        {
            board[i][j] = set;
        }
    }
}

void Show(char board[][ROWS], int row, int col)
{
    int i = 0;
    int j = 0;
    printf("-------------------------------\n");
    for (i = 0; i < row - 1; i++)
    {
        printf("%d ", i);
    }
    printf("\n");
    //遍歷數組,打印
    for (i = 1; i < row - 1; i++)
    {
        printf("%d ", i);
        for (j = 1; j < col - 1; j++)
        {
            printf("%c ", board[i][j]);
        }
        printf("\n");
    }
    printf("-------------------------------\n");
}

void SetMine(char board[][ROWS], int row, int col)
{
    int x;
    int y;
    int count = 0;
    //系統隨機設置10個范圍在1~9的x,y值,即隨機找十個雷的坐標
    srand((unsigned)time(NULL));
    for (int i = 0; i < MINE_NUM; i++)
    {
        x = rand() % row +1;
        y = rand() % row +1;
        board[x][y] = '1';
        count++;
    }
}
//字符'1' - 字符'0' = 數字1,坐標值都為字符,所以要轉化為數字要加字符‘0'
int MineCount(char Mine[][ROWS], int x, int y)
{
    return (Mine[x - 1][y - 1] + Mine[x - 1][y] + Mine[x - 1][y + 1] + Mine[x][y - 1] + Mine[x][y + 1] + Mine[x + 1][y - 1] + Mine[x + 1][y] + Mine[x + 1][y + 1])-(8*'0');
}
//找雷
void FindMine(char Mine[][ROWS], char MineInfo[][ROWS], int row, int col)
{
    int x = 0;
    int y = 0;
    int count = MINE_NUM;//用來控制循環
    int countmine = 0;
    //循環當中踩到雷退出循環,遊戲結束,未踩到雷count--,直至雷全找完,此時遊戲勝利
    while (count != 0)
    {
        printf("請輸入坐標:");
        scanf("%d%d", &x, &y);
        //判斷用戶輸入是否合法,不合法重新輸入坐標,合法則判斷當前坐標下是否有雷,有雷遊戲結束,沒雷count--,遊戲繼續
        if (x > 0 && x <= row && y > 0 && y <= col)
        {
            if (Mine[x][y] == '1')
            {
                printf("Boom!你被炸瞭!\n");
                Show(Mine, ROWS, ROWS);
                break;
            }
            else
            {
                countmine = MineCount(Mine, x, y);
                MineInfo[x][y] = countmine + '0';
                Show(MineInfo, ROWS, ROWS);
                count--;
            }
        }
        else
        {
            printf("坐標不合法,請重新輸入");
        }

易錯點

  • 該雷盤打印時是%c打印,後期檢查雷的個數時應返回整型,所以中間轉換需要知道:‘某數字’-字符’0’=該數字的整型
  • 數組越界怎麼辦 由於要統計當前所選坐標周圍的雷數,要考慮當用戶將坐標選在數組邊緣或四個角的位置該如何統計,此時需要給數組上下左右各擴充一行,設置初值時設為0,打印時隻打印中間部分,(如11*11的數組隻打印1~9列/行,第0行/列和第10列/行充當安全區域),這樣在統計雷時數組便不會越界。

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

推薦閱讀: