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 //防止頭文件被重復(fù)包含 #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)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++編程異常處理中try和throw以及catch語句的用法
這篇文章主要介紹了C++編程異常處理中try和throw以及catch語句的用法,包括對Catch塊的計算方式的介紹,需要的朋友可以參考下2016-01-01C++中的函數(shù)指針與函數(shù)對象的總結(jié)
以下是對C++中的函數(shù)指針與函數(shù)對象的使用進行了詳細的分析介紹,需要的朋友可以參考下2013-07-07JetBrains?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-01OpenCV實現(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-04C語言數(shù)據(jù)結(jié)構(gòu)之復(fù)雜鏈表的拷貝
復(fù)雜鏈表指的是一個鏈表有若干個結(jié)點,每個結(jié)點有一個數(shù)據(jù)域用于存放數(shù)據(jù),還有兩個指針域,其中一個指向下一個節(jié)點,還有一個隨機指向當(dāng)前復(fù)雜鏈表中的任意一個節(jié)點或者是一個空結(jié)點。今天我們要實現(xiàn)的就是對這樣一個復(fù)雜鏈表復(fù)制產(chǎn)生一個新的復(fù)雜鏈表2021-11-11