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

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

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

通過一段時間的C語言學習,想必小伙伴們也想躍躍欲試的編寫一些小程序,這個掃雷簡易游戲,非常適合C語言初學者去實踐。

實現(xiàn)掃雷,首先要有兩個棋盤,一個棋盤放置著雷的信息,另個用于展示到屏幕上;然后就是玩家輸入坐標排雷,如果輸入的坐標有雷,就游戲結束,要是沒有雷就在展示棋盤對應的位置,顯示出周邊雷的個數;最后排查完所有坐標并且不被雷炸死,就是勝利。

以上是掃雷的基本邏輯,現(xiàn)在開始,一步一步的實現(xiàn)。

1.初始化棋盤

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

mine就是放雷的棋盤,show就是展示出來棋盤。我們把mine都初始化成‘0',雷為‘1',show

都初始化為‘*'。

2.布置雷

void SetMine(char board[ROWS][COLS], int row, int col)
{
 int count = EASY_COUNT;//10個雷

 while (count)
 {
  //1. 生成隨機下標
  int x = rand() % row + 1;
  int y = rand() % col + 1;
  if (board[x][y] != '1')
  {
   board[x][y] = '1';
   count--;
  }
 }
}

3.排查雷

排查雷是本游戲關鍵,也稍有難度,首先,需要將倆個棋盤都傳過去,每次輸入坐標都會去雷盤里找,如果是雷就游戲結束,不是雷就會使對應的展示盤的位置 展現(xiàn)出周圍的雷數。

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<row*col - EASY_COUNT)
 {
  printf("請輸入要排查的坐標:>");
  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
   {
    int count = GetMineCount(mine, x, y);
    show[x][y] = count + '0';
    DisplayBoard(show, ROW, COL);
    win++;
   }
  }
  else
  {
   printf("坐標非法,重新輸入\n");
  }
 }

 if (win == row * col - EASY_COUNT)
 {
  printf("恭喜你,排雷成功\n");
  DisplayBoard(mine, ROW, COL);
 }
}

看(x,y)周圍雷數的函數:

int GetMineCount(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');
}

上面使掃雷游戲一步一步完成的步驟,接下來是游戲的運行代碼:

1.頭文件

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


#define ROW 9
#define COL 9

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

#define EASY_COUNT 10

//初始化棋盤
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);

2.游戲代碼

#include "game.h"

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

void DisplayBoard(char board[ROWS][COLS], int row, int col)
{
 int i = 0;
 printf("------------------------\n");
 for (i = 0; i <= 9; i++)
 {
  printf("%d ", i);
 }
 printf("\n");

 for (i = 1; i <= row; i++)
 {
  int j = 0;
  printf("%d ", i);
  for (j = 1; j <= col; j++)
  {
   printf("%c ", board[i][j]);
  }
  printf("\n");
 }
 printf("------------------------\n");
}


void SetMine(char board[ROWS][COLS], int row, int col)
{
 int count = EASY_COUNT;

 while (count)
 {
  //1. 生成隨機下標
  int x = rand() % row + 1;
  int y = rand() % col + 1;
  if (board[x][y] != '1')
  {
   board[x][y] = '1';
   count--;
  }
 }
}

int GetMineCount(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<row*col - EASY_COUNT)
 {
  printf("請輸入要排查的坐標:>");
  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
   {
    int count = GetMineCount(mine, x, y);
    show[x][y] = count + '0';
    DisplayBoard(show, ROW, COL);
    win++;
   }
  }
  else
  {
   printf("坐標非法,重新輸入\n");
  }
 }

 if (win == row * col - EASY_COUNT)
 {
  printf("恭喜你,排雷成功\n");
  DisplayBoard(mine, ROW, COL);
 }
}

3.總程序

#include "game.h"

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

void game()
{
 char mine[ROWS][COLS] = { 0 };//存放雷的信息
 char show[ROWS][COLS] = { 0 };//存放排查出的雷的信息
 //初始化一下棋盤
 InitBoard(mine, ROWS, COLS, '0');//'0'
 InitBoard(show, ROWS, COLS, '*');//'*'

 //布置雷
 SetMine(mine, ROW, COL);
 DisplayBoard(show, ROW, COL);

 //排查雷
 FindMine(mine, show, ROW, COL);
}

int main()
{
 int input = 0;
 srand((unsigned int)time(NULL));
 do
 {
  menu();
  printf("請選擇:>");
  scanf("%d", &input);
  switch (input)
  {
  case 1:
   game();
   break;
  case 0:
   printf("退出游戲\n");
   break;
  default:
   printf("選擇錯誤,重新選擇!\n");
   break;
  }
 } while (input);

 return 0;
}

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

相關文章

  • C語言實現(xiàn)投票系統(tǒng)

    C語言實現(xiàn)投票系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)投票系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • OpenCV實現(xiàn)物體的凸包檢測的示例代碼

    OpenCV實現(xiàn)物體的凸包檢測的示例代碼

    給定二維平面上的點集,凸包就是將最外層的點連接起來構成的凸邊形,它是包含點集中所有的點。本文將利用OpenCV實現(xiàn)物體的凸包檢測,感興趣的可以了解一下
    2022-08-08
  • C++內存對齊的實現(xiàn)

    C++內存對齊的實現(xiàn)

    本文主要介紹了C++內存對齊的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-02-02
  • C語言實現(xiàn)動態(tài)順序表的實現(xiàn)代碼

    C語言實現(xiàn)動態(tài)順序表的實現(xiàn)代碼

    這篇文章主要介紹了C語言實現(xiàn)動態(tài)順序表的實現(xiàn)代碼的相關資料,動態(tài)順序表在內存中開辟一塊空間,可以隨我們數據數量的增多來擴容,需要的朋友可以參考下
    2017-08-08
  • 淺談C++11的std::mem_fn源碼解析

    淺談C++11的std::mem_fn源碼解析

    本文是基于gcc-4.9.0的源代碼進行分析,std::mem_fn是C++11才加入標準的,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • C語言實現(xiàn)貪吃蛇游戲代碼

    C語言實現(xiàn)貪吃蛇游戲代碼

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)貪吃蛇游戲代碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • C++語言數據結構 串的基本操作實例代碼

    C++語言數據結構 串的基本操作實例代碼

    這篇文章主要介紹了C語言數據結構 串的基本操作實例代碼的相關資料,需要的朋友可以參考下
    2017-04-04
  • APUE筆記之:進程環(huán)境詳解

    APUE筆記之:進程環(huán)境詳解

    本篇文章是對APUE 進程環(huán)境詳解進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C++設計模式編程中的迭代器模式應用解析

    C++設計模式編程中的迭代器模式應用解析

    這篇文章主要介紹了C++設計模式編程中的迭代器模式應用解析,迭代器模式注重對集合中元素的遍歷而不使其暴露,需要的朋友可以參考下
    2016-03-03
  • C++中STL容器的主要使用及含義說明

    C++中STL容器的主要使用及含義說明

    這篇文章主要介紹了C++中STL容器的主要使用及含義說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11

最新評論