C語言實現(xiàn)掃雷游戲附注釋
概述
掃雷是一款大眾類的益智小游戲。游戲目標是根據(jù)點擊格子出現(xiàn)的數(shù)字找出所有非雷格子,同時避免踩雷,踩到一個雷即全盤皆輸。
實現(xiàn)過程
1、創(chuàng)建一個用戶交互菜單
2、布雷函數(shù)
3、顯示掃雷矩陣
4、玩家自定義坐標
5、計算排雷數(shù)
多文件實現(xiàn)
頭文件 clear_mine.h
#pragma once //防止頭文件被重復包含 #define _CRT_SECURE_NO_WARNINGS 1 //實現(xiàn) scanf 編譯通過 #include <stdio.h> #include <stdlib.h> #include <time.h> #include <windows.h> #define ROW 8 #define COL 8 #define STYLE '?' //初始化 #define NUM 20 //埋雷數(shù) extern void Game();
源文件main.c
向玩家展示菜單欄
#include "clear_mine.h"
static void Menu() //用戶交互菜單
{
printf("########################\n");
printf("# 1. Play 0.Exit #\n");
printf("########################\n");
}
int main()
{
int quit = 0;
int select = 0;
while (!quit)
{
Menu();
printf("Please Enter# ");
scanf("%d", &select);
switch (select)
{
case 1:
Game();
break;
case 0:
quit = 1;
break;
default:
printf("Position Error, Try Again!\n");
break;
}
}
printf("byebye!\n");
system("pause");
return 0;
}

源文件clear_mine.c
#include "clear_mine.h"
static void SetMines(char board[][COL], int row, int col) //布雷
{
int count = NUM;
while (count)
{
int x = rand() % (row - 2) + 1;
int y = rand() % (col - 2) + 1; //隨機數(shù)生成 矩陣長寬分別-2 的隨機數(shù)
if (board[x][y] == '0') //非法判斷 只能同一個位置生成一個隨機數(shù)
{
board[x][y] = '1';
count--;
}
}
}
static void ShowLine(int col)
{
for (int i = 0; i <= (col - 2); i++)
{
printf("----");
}
printf("\n");
}
static void ShowBoard(char board[][COL], int row, int col) //顯示掃雷矩陣
{
printf(" ");
for (int i = 1; i <= (col - 2); i++) //表頭數(shù)字打印
{
printf("%d ", i);
}
printf("\n");
ShowLine(col);
for (int i = 1; i <= (row - 2); i++)
{
printf("%-3d|", i);
for (int j = 1; j <= (col - 2); j++)
{
printf(" %c |", board[i][j]);
}
printf("\n");
ShowLine(col);
}
}
static char CountMines(char board[][COL], int x, int y) //計算某點周圍8個位置雷總數(shù)
{
return board[x - 1][y - 1] + board[x - 1][y] + board[x - 1][y + 1] + \
board[x][y + 1] + board[x + 1][y + 1] + board[x + 1][y] + \
board[x + 1][y - 1] + board[x][y - 1] - 7 * '0';
}
void Game()
{
srand((unsigned long)time(NULL)); //生成隨機數(shù)種子
char show_board[ROW][COL];
char mine_board[ROW][COL];
memset(show_board, STYLE, sizeof(show_board)); //生成用戶顯示矩陣
memset(mine_board, '0', sizeof(mine_board)); //生成掃雷矩陣
SetMines(mine_board, ROW, COL); //布雷
int count = (ROW - 2)*(COL - 2) - NUM; //排雷
while (count)
{
system("cls"); //清屏
ShowBoard(show_board, ROW, COL);
printf("Please Enter Your Position <x,y># ");
int x = 0;
int y = 0;
scanf("%d %d", &x, &y);
if (x < 1 || x > 10 || y < 1 || y > 10) //非法性判斷
{
printf("Postion Error!\n");
continue;
}
if (show_board[x][y] != STYLE){
printf("Postion Is not *\n");
continue;
}
if (mine_board[x][y] == '1'){
printf("game over!\n");
ShowBoard(mine_board, ROW, COL);
break;
}
show_board[x][y] = CountMines(mine_board, x, y);
count--;
}
}
初始化好的掃雷矩陣

游戲體驗結(jié)果

感興趣的小朋友可以嘗試下哦
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++編程異常處理中try和throw以及catch語句的用法
這篇文章主要介紹了C++編程異常處理中try和throw以及catch語句的用法,包括對Catch塊的計算方式的介紹,需要的朋友可以參考下2016-01-01
C++中的函數(shù)指針與函數(shù)對象的總結(jié)
以下是對C++中的函數(shù)指針與函數(shù)對象的使用進行了詳細的分析介紹,需要的朋友可以參考下2013-07-07
JetBrains?CLion永久激活超詳細教程(最新激活方法)
JetBrains?Clion?是一款專為?C/C++?開發(fā)所設(shè)計的跨平臺?IDE,本文適用?JetBrains?CLion?v2019.3/3.1/3.2/3.3?永久激活,附破解補丁和激活碼,可以永久激活?Windows、MAC、Linux?下的?CLion,下面給大家分享JetBrains?CLion永久激活超詳細教程,感興趣的朋友一起看看吧2023-01-01
OpenCV實現(xiàn)低對比度圖像臟污區(qū)域檢測
本文主要介紹了OpenCV實現(xiàn)低對比度圖像臟污區(qū)域檢測,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09
利用C語言實現(xiàn)任務(wù)調(diào)度的示例代碼
這篇文章主要為大家詳細介紹了如何利用純C語言實現(xiàn)任務(wù)調(diào)度(可用于STM32、C51等單片機),文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下2023-04-04
C語言數(shù)據(jù)結(jié)構(gòu)之復雜鏈表的拷貝
復雜鏈表指的是一個鏈表有若干個結(jié)點,每個結(jié)點有一個數(shù)據(jù)域用于存放數(shù)據(jù),還有兩個指針域,其中一個指向下一個節(jié)點,還有一個隨機指向當前復雜鏈表中的任意一個節(jié)點或者是一個空結(jié)點。今天我們要實現(xiàn)的就是對這樣一個復雜鏈表復制產(chǎn)生一個新的復雜鏈表2021-11-11

