亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

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

一、分析游戲步驟:

具體步驟如圖:

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

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

1、游戲主要實(shí)現(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);      //打印布雷的棋盤(pán)
 
 print_show(show, ROW, COL);      //打印棋盤(pán)
 
 int ret = -1;         //用于游戲中判斷是否是第一步
 
 while (1)          //玩家進(jìn)行游戲
 {
 int x, y;
 int num = -1;
 printf("請(qǐng)輸入坐標(biāo)< x y >:\n");
 scanf("%d%d", &x, &y);
 if (x < 1 || x>10 || y < 1 || x>10)
 {
 printf("輸入的坐標(biāo)有誤,請(qǐng)重新輸入:\n");
 }
 else
 {
 if (ret == -1 && mine[x][y] == '1')   //第一步踩雷
 {
 mine[x][y] = '0';      //除掉這個(gè)雷
 set_mine(mine, 1);     // 再布一顆雷
 }
 
 if (mine[x][y] == '0')  //沒(méi)有踩雷 
 {
 ret = 0;
 num = get_round_mine(mine, x, y);
 if (num != 0)
 {
  show[x][y] = num + '0';
 }
 else    //周?chē)蝗Χ紱](méi)有雷
 {
  open_show(mine, show, x, y); //展開(kāi)函數(shù) (連續(xù)展開(kāi))
 }
 print_show(show, ROW, COL);      //打印棋盤(pán)
 }
 
 else            // 踩雷了
 {
 printf("少俠,你踩到雷了!??!\n");
 print_show(mine, ROW, COL);      //打印棋盤(pán)
 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)   //打印棋盤(pán)
{
 
 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) //獲取周?chē)椎膫€(gè)數(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) //展開(kāi)函數(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("請(qǐng)選擇游戲進(jìn)程: \n");
 do {
 menu();
 scanf("%d", &input);
 switch (input) {
 case 1:
 game();    //主游戲 
 break;
 case 0:
 break;
 default:
 printf("選擇錯(cuò)誤,客官請(qǐng)重新選擇:\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    //棋盤(pán)大小
#define COL 10
#define MINE_NUM 10   //雷的個(gè)數(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);     //打印棋盤(pán)
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);   //獲取周?chē)椎膫€(gè)數(shù);
void open_show(char mine[ROW + 2][COL + 2], char show[ROW + 2][COL + 2], int x, int y); //展開(kāi)函數(shù)
int Is_win(char show[ROW + 2][COL + 2]);   //判贏
 
#endif

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

相關(guān)文章

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

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

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

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

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

    Opengl?ES之FBO幀緩沖對(duì)象使用詳解

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

    C++入門(mén)教程之引用與指針

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

    C語(yǔ)言折半查找法的超詳細(xì)講解

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

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

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

    解析C++引用

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

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

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

    C++ 構(gòu)造函數(shù)中使用new時(shí)注意事項(xiàng)

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

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

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

最新評(píng)論