欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言實(shí)現(xiàn)掃雷游戲(可展開)

 更新時(shí)間:2021年09月10日 15:34:52   作者:快滾去碼字  
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)掃雷游戲,實(shí)現(xiàn)掃雷展開和提醒,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了C語言實(shí)現(xiàn)掃雷游戲的具體代碼,供大家參考,具體內(nèi)容如下

# 一、游戲的思路

先理清游戲大概需要實(shí)現(xiàn)的功能,菜單功能的實(shí)現(xiàn)、棋盤初始化、打印棋盤、布置雷等。運(yùn)用兩個(gè)數(shù)組,一個(gè)放入布置雷的信息,另一個(gè)放入排查雷的信息。選一個(gè)坐標(biāo)掃雷,坐標(biāo)有雷則游戲結(jié)束,沒有就計(jì)算選中坐標(biāo)的周圍8個(gè)格子中雷的總數(shù)放入選中的坐標(biāo)中,若選中的坐標(biāo)周圍8個(gè)格子中都沒有雷則自動(dòng)展開??紤]到棋盤邊框的情況,實(shí)際數(shù)組要比打印出的棋盤多兩行兩列。下面是宏定義和函數(shù)聲明:

ROW、COL為打印行、列,ROWS、COLS為實(shí)際的數(shù)組行列
EASY_COUNT為雷的個(gè)數(shù),可根據(jù)需要調(diào)整行列和雷的個(gè)數(shù)

#define ROW 9
#define COL 9

#define ROWS ROW+2
#define COLS COL+2

#define EASY_COUNT 10

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<Windows.h>

void InitBoard(char board[ROWS][COLS], int rows, int cols, char set);
void DisplayBoard(char board[ROWS][COLS], int row, int col);
void SetMine(char board[ROWS][COLS], int row, int col);
void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);
void ExcludeMine(char mine[ROWS][COLS], char show[ROWS][COLS], int x, int y);

二、游戲測(cè)試

游戲?qū)崿F(xiàn)的大致思路體現(xiàn)和菜單的實(shí)現(xiàn),代碼如下:

#define _CRT_SECURE_NO_WARNINGS 1

#include"game.h"

void menu()
{
 printf("##############################\n");
 printf("###### 1. play 0.exit ######\n");
 printf("##############################\n");
}

//布置雷 - 字符組存儲(chǔ) - 雷用1表示,非雷用0表示 - 最外層一圈放0
//排查雷 - 為避免歧義,再用一個(gè)字符組存儲(chǔ)排查出來的雷的信息 - 未排除的用#表示
//最外層加一圈字符,只在中間設(shè)置雷,并打印展示棋盤中間位置,因此實(shí)際存放數(shù)組要比打印的棋盤多兩行兩列
void game()
{
 //雷的信息存儲(chǔ)
 //1.布置好的雷的信息
 char mine[ROWS][COLS] = { 0 };
 //2.排查出的雷的信息
 char show[ROWS][COLS] = { 0 };
 //初始化
 InitBoard(mine, ROWS, COLS, '0');
 InitBoard(show, ROWS, COLS, '#');
 //打印棋盤
 //DisplayBoard(mine, ROW, COL);//測(cè)試使用
 DisplayBoard(show, ROW, COL);
 //布置雷
 SetMine(mine, ROW, COL);
 //DisplayBoard(mine, ROW, COL);//測(cè)試使用
 //掃雷
 FindMine(mine, show, ROW, COL);
}

void test()
{
 int input = 0;
 srand((unsigned int)time(NULL));
 do
 {
 menu();
 printf("請(qǐng)選擇:>");
 scanf("%d", &input);
 switch(input)
 {
 case 1:
 game();
 printf("將返回主菜單\n");
 Sleep(5 * 1000);
 break;
 case 0:
 printf("退出游戲\n");
 break;
 default:
 printf("選擇錯(cuò)誤,請(qǐng)重新選擇\n");
 break;
 }
 } while (input);
}

int main()
{
 test();
 return 0;
}

三、游戲流程

存放函數(shù)的源文件需要引用頭文件

#define _CRT_SECURE_NO_WARNINGS 1
#include "game.h"

1.初始化棋盤

void InitBoard(char board[ROWS][COLS], int rows, int cols, char set)
{
 int i = 0;
 int j = 0;
 for (i = 0; i < rows; i++)
 {
 for (j = 0; j < cols; j++)
 {
 board[i][j] = set;
 }
 }
}

2.棋盤打印

void DisplayBoard(char board[ROWS][COLS], int row, int col)
{
 int i = 0;
 int j = 0;
 //打印列號(hào)
 for (i = 0; i <= col; i++)
 {
 printf("%d ", i);
 }
 printf("\n");
 for (i = 1; i <= row; i++)
 {
 printf("%d ", i);
 for (j = 1; j <= col; j++)
 {
 printf("%c ", board[i][j]);
 }
 printf("\n");
 }
}

3.布置雷

void SetMine(char board[ROWS][COLS], int row, int col)
{
 int count = EASY_COUNT;
 while (count)
 {
 int x = rand() % row + 1;//1-9
 int y = rand() % col + 1;
 if (board[x][y] == '0')
 {
 board[x][y] = '1';
 count--;
 }
 }
}

4.查找雷和勝負(fù)判斷

int CheckShow(char show[ROWS][COLS], int row, int col)
{
 int win = 0;
 int i = 0;
 int j = 0;
 for (i = 1; i <= row; i++)
 {
 for (j = 1; j <= col; j++)
 {
 if (show[i][j] == '#')
 win++;
 }
 }
 return win;
}

void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{
 int x = 0;
 int y = 0;
 int win = 0;
 //9*9 - 10 = 71
 while (1)
 {
 printf("請(qǐng)輸入排查雷的坐標(biāo):>");
 scanf("%d%d", &x, &y);
 if (x >= 1 && x <= row && y >= 1 && y <= col)
 {
 //坐標(biāo)合法
 //1.踩雷
 if (mine[x][y] == '1')
 {
 printf("很遺憾,你被炸死了\n");
 DisplayBoard(mine, row, col);
 break;
 }
 else//不是雷
 {
 //計(jì)算x,y坐標(biāo)周圍有幾個(gè)雷
 ExcludeMine(mine, show, x, y);
 DisplayBoard(show, row, col);
 win = CheckShow(show, row, col);
 if (win == EASY_COUNT)
  break;
 }
 }
 else
 {
 printf("坐標(biāo)非法,請(qǐng)重新輸入!\n");
 }
 }
 if (win == EASY_COUNT)
 {
 printf("恭喜你,排雷成功\n");
 DisplayBoard(mine, row, col);
 }
}

5.掃雷的展開和提醒

//'1' - '0' = 1
int get_mine_count(char mine[ROWS][COLS], int x, int y)
{
 return mine[x - 1][y] +
 mine[x - 1][y - 1] +
 mine[x][y - 1] +
 mine[x + 1][y - 1] +
 mine[x + 1][y] +
 mine[x + 1][y + 1] +
 mine[x][y + 1] +
 mine[x - 1][y + 1] - 8 * '0';
}

void ExcludeMine(char mine[ROWS][COLS], char show[ROWS][COLS], int x, int y)
{
 int count = get_mine_count(mine, x, y);
 if (count != 0)
 {
 show[x][y] = count + '0';
 }
 else
 {
 show[x][y] = ' ';
 if (show[x - 1][y] == '#')
 ExcludeMine(mine, show, x - 1, y);
 if (show[x - 1][y - 1] == '#')
 ExcludeMine(mine, show, x - 1, y - 1);
 if (show[x][y - 1] == '#')
 ExcludeMine(mine, show, x, y - 1);
 if (show[x + 1][y - 1] == '#')
 ExcludeMine(mine, show, x + 1, y - 1);
 if (show[x + 1][y] == '#')
 ExcludeMine(mine, show, x + 1, y);
 if (show[x + 1][y + 1] == '#')
 ExcludeMine(mine, show, x + 1, y + 1);
 if (show[x][y + 1] == '#')
 ExcludeMine(mine, show, x, y + 1);
 if (show[x - 1][y + 1] == '#')
 ExcludeMine(mine, show, x - 1, y + 1);
 }
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C++實(shí)現(xiàn)LeetCode(61.旋轉(zhuǎn)鏈表)

    C++實(shí)現(xiàn)LeetCode(61.旋轉(zhuǎn)鏈表)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(61.旋轉(zhuǎn)鏈表),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C語言實(shí)現(xiàn)餐飲點(diǎn)餐管理系統(tǒng)

    C語言實(shí)現(xiàn)餐飲點(diǎn)餐管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)餐飲點(diǎn)餐管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • C++?容器中map和unordered?map區(qū)別詳解

    C++?容器中map和unordered?map區(qū)別詳解

    這篇文章主要為大家介紹了C++?容器中map和unordered?map區(qū)別示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • 詳解C++循環(huán)創(chuàng)建多級(jí)目錄及判斷目錄是否存在的方法

    詳解C++循環(huán)創(chuàng)建多級(jí)目錄及判斷目錄是否存在的方法

    這篇文章主要介紹了C++循環(huán)創(chuàng)建多級(jí)目錄及判斷目錄是否存在的方法,文中代碼有一個(gè)針對(duì)各種系統(tǒng)進(jìn)行判斷來加載不同頭文件的方法,需要的朋友可以參考下
    2016-03-03
  • C++基于消息隊(duì)列的多線程實(shí)現(xiàn)示例代碼

    C++基于消息隊(duì)列的多線程實(shí)現(xiàn)示例代碼

    這篇文章主要給大家介紹了關(guān)于C++基于消息隊(duì)列的多線程實(shí)現(xiàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用C++具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • C語言函數(shù)調(diào)用約定和返回值詳情

    C語言函數(shù)調(diào)用約定和返回值詳情

    這篇文章主要介紹了C語言函數(shù)調(diào)用約定和返回值詳情,函數(shù)調(diào)用約定不同,會(huì)影響函數(shù)生成的符號(hào)名,函數(shù)入?yún)㈨樞?,形參?nèi)存的清理者,更多相關(guān)需要的小伙伴可以參考下文詳情介紹
    2022-07-07
  • C++ 自定義棧實(shí)現(xiàn)迷宮求解

    C++ 自定義棧實(shí)現(xiàn)迷宮求解

    這篇文章主要介紹了C++ 自定義棧實(shí)現(xiàn)迷宮求解的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • C++實(shí)現(xiàn)判斷字符串是否回文實(shí)例解析

    C++實(shí)現(xiàn)判斷字符串是否回文實(shí)例解析

    這篇文章主要介紹了C++實(shí)現(xiàn)判斷字符串是否回文,其中采用了數(shù)據(jù)結(jié)構(gòu)中棧以及過濾字符等技術(shù),,需要的朋友可以參考下
    2014-07-07
  • C語言可變參數(shù)函數(shù)詳解示例

    C語言可變參數(shù)函數(shù)詳解示例

    一般我們編程的時(shí)候,函數(shù)中形式參數(shù)的數(shù)目通常是確定的,在調(diào)用時(shí)要依次給出與形式參數(shù)對(duì)應(yīng)的實(shí)際參數(shù)。但在某些情況下我們希望函數(shù)的參數(shù)個(gè)數(shù)可以根據(jù)需要確定,因此c語言引入可變參數(shù)函數(shù)。典型的可變參數(shù)函數(shù)的例子有printf()、scanf()等,下面我就開始講解
    2013-11-11
  • C++11 模板參數(shù)的“右值引用”是轉(zhuǎn)發(fā)引用嗎

    C++11 模板參數(shù)的“右值引用”是轉(zhuǎn)發(fā)引用嗎

    這篇文章主要介紹了C++11 模板參數(shù)的“右值引用”是轉(zhuǎn)發(fā)引用嗎,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05

最新評(píng)論