基于C語言代碼實(shí)現(xiàn)掃雷游戲
更新時(shí)間:2020年11月10日 08:40:04 作者:楠c
這篇文章主要為大家詳細(xì)介紹了基于C語言代碼實(shí)現(xiàn)掃雷游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本文實(shí)例為大家分享了C語言實(shí)現(xiàn)掃雷游戲的具體代碼,供大家參考,具體內(nèi)容如下
掃雷(第一次多文件應(yīng)用)
掃雷的思路

game.h
#ifndef _GAME_H_ #define _GAME_H_ #include<stdio.h> #include <time.h> #include<string.h> #include<windows.h> #pragma warning(disable:4996) #define ROW 12 #define COL 12 //定義20個(gè)雷 #define NUMS 20 void Menu(); void Game(); #endif
main.c
#include "game.h"
int main(){
int quit = 0;
int select = 0;
while (!quit){
Menu();
scanf("%d", &select);
switch (select){
case 1:
Game();
break;
case 2:
quit = 1;
break;
default:
printf("請(qǐng)重新輸入");
break;
}
}
system("pause");
return 0;
}
game.c
#include "game.h"
void Menu()
{
printf("##########################\n");
printf("## 1. Play 2. Exit ##\n");
printf("##########################\n");
printf("請(qǐng)輸入# ");
}
//設(shè)置20個(gè)隨機(jī)雷
void SetMines(char mine_board[][COL], int row, int col)
{
int count = NUMS;
while (count){
int x = rand() % 10 + 1;
int y = rand() % 10 + 1;
if (mine_board[x][y] == '0'){
mine_board[x][y] = '1';
count--;
}
}
}
//判斷周圍有幾個(gè)雷
int GetMines(char mine[][COL], int row, int col, 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';
}
//設(shè)置界面的下劃線
static void ShowLine(int nums)
{
printf("---");
for (int i = 0; i < nums; i++){
printf("-");
}
printf("\n");
}
//一個(gè)顯示界面,傳入界面數(shù)組顯示掃雷界面,傳入布雷數(shù)組顯示雷區(qū)界面
void ShowBoard(char show_board[][COL], int row, int col)
{
printf(" ");
for (int i = 1; i < row - 1; i++){
printf(" %d ", i);
}
printf("\n");
ShowLine(2 * col + col + 4);
for (int i = 1; i < row - 1; i++){
printf("%2d|", i);
for (int j = 1; j < col - 1; j++){
printf(" %c |", show_board[i][j]);
}
printf("\n");
ShowLine(2 * col + col + 4);
}
}
void Game()
{
char show_board[ROW][COL];
char mine_board[ROW][COL];
memset(show_board, '*', sizeof(show_board));
memset(mine_board, '0', sizeof(mine_board));
srand((unsigned long)time(NULL));
SetMines(mine_board, ROW, COL);
int count = (ROW - 2)*(COL - 2) - NUMS;
int x = 0;
int y = 0;
do{
ShowBoard(show_board, ROW, COL);
printf("請(qǐng)輸入位置# ");
scanf("%d %d", &x, &y);
if (x < 1 || x > 10 || y < 1 || y >10){
printf("輸入越界,請(qǐng)重新輸入!\n");
continue;
}
if (show_board[x][y] != '*'){
printf("該位置已經(jīng)被排除,請(qǐng)重新輸入!\n");
continue;
}
if (mine_board[x][y] == '1'){
break;
}
int num = GetMines(mine_board, ROW, COL, x, y);
show_board[x][y] = num + '0';
count--;
system("cls");
} while (count > 0);
//count>0說明坐標(biāo)是雷,break提前退出了
if (count > 0){
printf("你被炸死了!\n");
}
else{
printf("你贏了!\n");
}
printf("下面是雷區(qū)的排布!\n");
ShowBoard(mine_board, ROW, COL);
}
更多有趣的經(jīng)典小游戲?qū)崿F(xiàn)專題,分享給大家:
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
數(shù)據(jù)結(jié)構(gòu)順序表操作示例
這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu)順序表操作示例,其中有在第I個(gè)元素前插入數(shù)據(jù)x,元素從0開始計(jì)數(shù)、刪除第i個(gè)元素,元素從0開始計(jì)數(shù)的方法,需要的朋友可以參考下2014-03-03
C++實(shí)現(xiàn)LeetCode(92.倒置鏈表之二)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(倒置鏈表之二),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C語言時(shí)間函數(shù)的ctime()和gmtime()你了解嗎
這篇文章主要為大家詳細(xì)介紹了C語言時(shí)間函數(shù)的ctime()和gmtime(),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-02-02
C語言如何實(shí)現(xiàn)Unix時(shí)間戳與本地時(shí)間轉(zhuǎn)化
這篇文章主要介紹了C語言如何實(shí)現(xiàn)Unix時(shí)間戳與本地時(shí)間轉(zhuǎn)化的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03

