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

C語言快速實現(xiàn)掃雷小游戲

 更新時間:2020年09月22日 10:43:08   作者:Zero_975  
這篇文章主要為大家詳細介紹了C語言實現(xiàn)掃雷小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

一、分析游戲步驟:

具體步驟如圖:

二、代碼實現(xiàn):

游戲步驟想好之后,就是用代碼把步驟一步一步的實現(xiàn)。具體代碼如下:

1、游戲主要實現(xiàn): game.c

#define _CRT_SECURE_NO_WARNINGS 1
 
#include"game.h"
 
void game()
{
 char mine[ROW + 2][COL + 2];     //記錄地雷的數(shù)組
 char show[ROW + 2][COL + 2];     //展示給玩家的數(shù)組
 
 Init(mine, show, ROW + 2, COL + 2);    //初始化
 set_mine(mine, MINE_NUM);      //布雷
 
 //print_show(mine, ROW, COL);      //打印布雷的棋盤
 
 print_show(show, ROW, COL);      //打印棋盤
 
 int ret = -1;         //用于游戲中判斷是否是第一步
 
 while (1)          //玩家進行游戲
 {
 int x, y;
 int num = -1;
 printf("請輸入坐標< x y >:\n");
 scanf("%d%d", &x, &y);
 if (x < 1 || x>10 || y < 1 || x>10)
 {
 printf("輸入的坐標有誤,請重新輸入:\n");
 }
 else
 {
 if (ret == -1 && mine[x][y] == '1')   //第一步踩雷
 {
 mine[x][y] = '0';      //除掉這個雷
 set_mine(mine, 1);     // 再布一顆雷
 }
 
 if (mine[x][y] == '0')  //沒有踩雷 
 {
 ret = 0;
 num = get_round_mine(mine, x, y);
 if (num != 0)
 {
  show[x][y] = num + '0';
 }
 else    //周圍一圈都沒有雷
 {
  open_show(mine, show, x, y); //展開函數(shù) (連續(xù)展開)
 }
 print_show(show, ROW, COL);      //打印棋盤
 }
 
 else            // 踩雷了
 {
 printf("少俠,你踩到雷了!?。n");
 print_show(mine, ROW, COL);      //打印棋盤
 return;
 }
 }
 
 if (Is_win(show))
 {
 printf("恭喜?。?!您勝利啦!!!\n");
 break;
 }
 }
}
 
 
void Init(char mine[ROW + 2][COL + 2], char show[ROW + 2][COL + 2], int row, int col)
{
 memset(mine, '0', row*col * sizeof(mine[0][0]));
 memset(show, '*', row*col * sizeof(show[0][0]));
}
 
void print_show(char show[ROW + 2][COL + 2], int row, int col)   //打印棋盤
{
 
 int i;
 int j;
 printf(" ");
 for (i = 1; i <= col; i++)
 {
 printf("%2d", i);
 }
 printf("\n ");
 for (i = 0; i < col; i++)
 {
 printf("--");
 }
 printf("\n");
 for (i = 1; i <= row; i++)
 {
 printf("%2d|", i);
 for (j = 1; j <= col; j++)
 {
 printf("%2c", show[i][j]);
 }
 printf("\n");
 }
 printf("\n");
}
 
void set_mine(char mine[ROW + 2][COL + 2], int mineNumber)   //布雷
{
 int x = -1;
 int y = -1;
 while (mineNumber)
 {
 x = rand() % ROW + 1;
 y = rand() % COL + 1;
 if (mine[x][y] == '0')
 {
 mine[x][y] = '1';
 --mineNumber;
 }
 }
}
 
int get_round_mine(char mine[ROW + 2][COL + 2], int x, int y) //獲取周圍雷的個數(shù);
{
 return (mine[x - 1][y - 1]) + (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]) - 8 * '0';
}
 
void open_show(char mine[ROW + 2][COL + 2], char show[ROW + 2][COL + 2], int x, int y) //展開函數(shù)
{
 if (x >= 1 && x <= 10 && y >= 1 && y <= 10 && (mine[x][y] != 1) && (show[x][y] == '*'))
 {
 if (get_round_mine(mine, x, y) > 0)
 {
 show[x][y] = get_round_mine(mine, x, y) + '0';
 }
 else
 {
 show[x][y] = ' ';
 open_show(mine, show, x - 1, y - 1);
 open_show(mine, show, x - 1, y);
 open_show(mine, show, x - 1, y + 1);
 open_show(mine, show, x, y + 1);
 open_show(mine, show, x, y - 1);
 open_show(mine, show, x + 1, y - 1);
 open_show(mine, show, x + 1, y);
 open_show(mine, show, x + 1, y + 1);
 }
 }
}
 
int Is_win(char show[ROW + 2][COL + 2])  //判贏
{
 int count = MINE_NUM;
 int i;
 int j;
 for (i = 1; i <= ROW; i++)
 {
 for (j = 1; j <= ROW; j++)
 {
 if (show[i][j] == '*')
 {
 count--;
 }
 }
 }
 if (count == 0)  //雷全部找到
 {
 return 1;
 }
 else
 {
 return 0;
 }
}

2、游戲源文件:main.c

代碼如下:

#define _CRT_SECURE_NO_WARNINGS 1
 
#include"game.h"
 
void menu()   //菜單
{
 printf("###################################\n");
 printf("############# 1.play ############\n");
 printf("############# 0.exit ############\n");
 printf("###################################\n");
 
}
 
int main()
{
 srand((unsigned int)time(NULL));
 int input = 1;
 printf("請選擇游戲進程: \n");
 do {
 menu();
 scanf("%d", &input);
 switch (input) {
 case 1:
 game();    //主游戲 
 break;
 case 0:
 break;
 default:
 printf("選擇錯誤,客官請重新選擇:\n");
 break;
 }
 } while (input);
 
 
 system("pause");
 return 0;
}

3、游戲頭文件:game.h

代碼如下:

#pragma once
 
#ifndef _GAME_H_
#define _GAME_H_
 
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<windows.h>
#include<time.h>
 
 
#define ROW 10    //棋盤大小
#define COL 10
#define MINE_NUM 10   //雷的個數(shù)
 
void game();
 
void Init(char mine[ROW + 2][COL + 2], char show[ROW + 2][COL + 2], int row, int col); //初始化
void print_show(char show[ROW + 2][COL + 2], int row, int col);     //打印棋盤
void set_mine(char mine[ROW + 2][COL + 2], int mineNumber);      //布雷
int get_round_mine(char mine[ROW + 2][COL + 2], int x, int y);   //獲取周圍雷的個數(shù);
void open_show(char mine[ROW + 2][COL + 2], char show[ROW + 2][COL + 2], int x, int y); //展開函數(shù)
int Is_win(char show[ROW + 2][COL + 2]);   //判贏
 
#endif

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • C++圖像加載之libpng、FreeImage、stb_image詳解

    C++圖像加載之libpng、FreeImage、stb_image詳解

    libpng、FreeImage、stb_image都是圖像解析的開源庫,這篇文章主要為大家詳細介紹了這三者的使用方法,文中的示例代碼講解詳細,需要的可以參考一下
    2023-06-06
  • Visual Studio 2022 的安裝和創(chuàng)建C++項目(圖文教程)

    Visual Studio 2022 的安裝和創(chuàng)建C++項目(圖文教程)

    本文主要介紹了Visual Studio 2022 的安裝和創(chuàng)建C++項目,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-05-05
  • Opengl?ES之FBO幀緩沖對象使用詳解

    Opengl?ES之FBO幀緩沖對象使用詳解

    這篇文章主要為大家介紹了Opengl?ES之FBO幀緩沖對象使用詳解,<BR>有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • C++入門教程之引用與指針

    C++入門教程之引用與指針

    初學C++時,很容易把指針和引用的用法混在一起,下面這篇文章主要給大家介紹了關于C++入門教程之引用與指針的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-12-12
  • C語言折半查找法的超詳細講解

    C語言折半查找法的超詳細講解

    折半查找法也叫做?分查找,顧名思義就是把數(shù)據(jù)分成兩半,再判斷所查找的key在哪?半中,再重復上述步驟知道找到?標key,下面這篇文章主要給大家介紹了關于C語言折半查找法的相關資料,需要的朋友可以參考下
    2022-06-06
  • C++ string與int的相互轉(zhuǎn)換(使用C++11)

    C++ string與int的相互轉(zhuǎn)換(使用C++11)

    本文主要介紹了C++ string與int的相互轉(zhuǎn)換(使用C++11),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • 解析C++引用

    解析C++引用

    引用是C++引入的新語言特性,是C++常用的一個重要內(nèi)容之一。在工作中發(fā)現(xiàn),許多人使用它僅僅是想當然,在某些微妙的場合,很容易出錯,究其原由,大多因為沒有搞清本源。在本篇中將對引用進行詳細討論,希望對大家更好地理解和使用引用起到拋磚引玉的作用
    2021-06-06
  • C++中4種類型轉(zhuǎn)換的方法分享

    C++中4種類型轉(zhuǎn)換的方法分享

    這篇文章主要為大家詳細介紹了C++中4種類型轉(zhuǎn)換的方法,文中的示例代碼講解詳細,對我們學習C++有一定的幫助,感興趣的可以了解一下
    2023-04-04
  • C++ 構造函數(shù)中使用new時注意事項

    C++ 構造函數(shù)中使用new時注意事項

    本文主要介紹了C++ 構造函數(shù)中使用new時注意事項。具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02
  • kernel劫持modprobe?path內(nèi)容詳解

    kernel劫持modprobe?path內(nèi)容詳解

    這篇文章主要為大家介紹了kernel劫持modprobe?path的內(nèi)容詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05

最新評論