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

用C語言實現(xiàn)排雷游戲

 更新時間:2022年01月19日 09:43:41   作者:莫陌尛.  
大家好,本篇文章主要講的是用C語言實現(xiàn)排雷游戲,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下

設(shè)計簡單的游戲界面菜單

在這里插入圖片描述

輸入數(shù)字1,進入游戲;

在這里插入圖片描述

輸入數(shù)字0,退出游戲;輸入其他數(shù)字,將顯示輸入錯誤,重新輸入;

在這里插入圖片描述

排雷過程

輸入坐標,將顯示是否排到雷,或者沒有。

在這里插入圖片描述

顯示的數(shù)字,將是該坐標周圍八個坐標總共有幾個雷。(如圖,則有3顆)。如果輸入的坐標超出坐標范圍,將會提示,坐標非法輸入,重新輸入。

在這里插入圖片描述

如果你輸入的坐標有雷,將會出現(xiàn),你被炸,游戲結(jié)束!

在這里插入圖片描述

如果排雷成功,將顯示你成功排雷。(這里設(shè)置了雷數(shù)是80個,將直接操作顯示出來)。

在這里插入圖片描述

相應(yīng)的代碼

測試代碼在------text.c
#include"game.h"

void menu()
{
printf("****************\n");
printf(" 1. PLAY *\n");
printf(" 0. EXIT ******\n");
printf("*******************\n");
}
void game()
{
//雷的信息;
//1.布置雷的信息;
char mine[ROWS][COLS]={0};//1111
//2.排查雷
char show[ROWS][COLS]={0};
//初始化;
InitBoard(mine,ROWS,COLS,‘0');
InitBoard(show,ROWS,COLS,'');
//打印棋盤;
//DisplayBoard(mine,ROW,COL);
DisplayBoard(show,ROW,COL);
//布置雷;
SetMine(mine,ROW,COL);
DisplayBoard(mine,ROW,COL);
//掃雷;
FindMine(mine,show,ROW,COL);
}
void test()
{
int input = 0;
srand((unsigned int)time(NULL));
do
{
menu();
printf(“請選擇:>\n”);
scanf("%d",&input);
switch(input)
{
case 1:
game();
break;
case 0:
printf(“退出游戲\n”);
break;
default:
printf(“選擇錯誤,請重新選擇!\n”);
break;
}
}
while(input);
}
int main()
{
test();
return 0;
}


2. 函數(shù)的聲明
#define ROW 9 //顯示時棋盤的行數(shù);
#define COL 9 //顯示時棋盤的列數(shù);

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

#define EASY_COUNT 10 //雷的總數(shù);

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

void InitBoard(char board[ROWS][COLS],int rows,int cols,int set);
void DisplayBoard(char board[ROW][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);


3. 相關(guān)函數(shù)的定義
#include “game.h”
void InitBoard(char board[ROWS][COLS],int rows,int cols,int set)
{
int i = 0;
int j = 0;
for(i = 0;i<=rows;i++)
{
for(j = 0;j<=cols;j++)
{
board[i][j] = set;
}
}
}

void DisplayBoard(char board[ROW][COLS],int row,int col)
{
int i = 0;
int j = 0;
//打印列號;
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");
}
}

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

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 FindMine(char mine[ROWS][COLS],char show[ROWS][COLS],int row,int col)
{
int x = 0;
int y = 0;
int win = 0;
while(win<rowcol-EASY_COUNT)
{
printf(“請輸入坐標:>\n”);
scanf("%d%d",&x,&y);
if(x>=1&&x<=row&&y>=1&&y<=col)
{
if(mine[x][y]‘1')
{
printf(“很遺憾,你被炸死了\n”);
DisplayBoard(mine,ROW,COL);
break;
}
else//計算雷的個數(shù);
{
int count = get_mine_count(mine,x,y);
show[x][y]=count+‘0';
DisplayBoard(show,ROW,COL);
win++;
}
}
else
{
printf(“輸入非法坐標,請重新輸入\n”);
}
}
if(winrowcol-EASY_COUNT)
{
printf(“恭喜你,排雷成功\n”);
DisplayBoard(mine,ROW,COL);
}
}

一級目錄排雷游戲的缺陷與不足

設(shè)計排雷游戲非常的簡易,而且對于輸入坐標只能一個一個排,并不能在一定的情況下,將不是雷的空位顯示出來,所以排雷過程中需要花費大量的時間。設(shè)計上面并不是很美觀,只能是簡易的游戲!

一級目錄改進

需要運用遞歸去改進排雷游戲中關(guān)鍵的一步!

總結(jié)

到此這篇關(guān)于用C語言實現(xiàn)排雷游戲的文章就介紹到這了,更多相關(guān)C語言排雷游戲內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C迷途指針詳解

    C迷途指針詳解

    這篇文章主要介紹了C迷途指針,迷途指針又稱為懸空指針、野指針,其對C程序的安全性與穩(wěn)定性影響巨大,本文對其原理與檢測方法做了較為詳盡的分析,需要的朋友可以參考下
    2014-09-09
  • C++ OpenCV實戰(zhàn)之圖像全景拼接

    C++ OpenCV實戰(zhàn)之圖像全景拼接

    本文主要介紹了如何使用OpenCV C++ 進行圖像全景拼接,文中的示例代碼講解詳細,對我們學(xué)習(xí)OpenCV有一定的幫助,感興趣的可以了解一下
    2022-01-01
  • Qt數(shù)據(jù)庫應(yīng)用之實現(xiàn)通用數(shù)據(jù)庫清理

    Qt數(shù)據(jù)庫應(yīng)用之實現(xiàn)通用數(shù)據(jù)庫清理

    項目如果需要存儲很多日志記錄比如運行日志,時間長了記錄數(shù)量非常多,數(shù)據(jù)庫體積不斷增大,對應(yīng)數(shù)據(jù)庫表的增刪改查的效率不斷降低,因此需要將早期的數(shù)據(jù)清理。本文將詳細介紹一下通用數(shù)據(jù)庫清理的實現(xiàn),需要的可以參考一下
    2022-02-02
  • C++實現(xiàn)保存數(shù)據(jù)至EXCEL

    C++實現(xiàn)保存數(shù)據(jù)至EXCEL

    這篇文章主要介紹了C++實現(xiàn)保存數(shù)據(jù)至EXCEL,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • OpenCV實現(xiàn)彩色照片轉(zhuǎn)換成素描卡通片

    OpenCV實現(xiàn)彩色照片轉(zhuǎn)換成素描卡通片

    這篇文章主要為大家詳細介紹了OpenCV實現(xiàn)彩色照片轉(zhuǎn)換成素描卡通片,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • C++ xxx_cast實現(xiàn)轉(zhuǎn)換代碼實例解析

    C++ xxx_cast實現(xiàn)轉(zhuǎn)換代碼實例解析

    這篇文章主要介紹了C++xxx_cast轉(zhuǎn)換代碼實例解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-07-07
  • C++實現(xiàn)大整數(shù)乘法

    C++實現(xiàn)大整數(shù)乘法

    這篇文章主要為大家詳細介紹了C++實現(xiàn)大整數(shù)乘法,使用笛卡爾相乘,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • C語言實現(xiàn)隨機搶紅包功能

    C語言實現(xiàn)隨機搶紅包功能

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)隨機搶紅包功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • C++從匯編的視角審視對象的創(chuàng)建問題

    C++從匯編的視角審視對象的創(chuàng)建問題

    這篇文章主要介紹了C++從匯編的視角看對象的創(chuàng)建,從匯編的視角來看,調(diào)用構(gòu)造器和調(diào)用 “返回對象” 的函數(shù)是一樣的,從匯編的角度來看,對象就是一堆數(shù)據(jù)的排列,比如說最普通的對象就是數(shù)據(jù)成員按照聲明順序直接排列,需要的朋友可以參考下
    2022-01-01
  • C語言實現(xiàn)會員計費系統(tǒng)

    C語言實現(xiàn)會員計費系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)會員計費系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05

最新評論