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

用C語言實現(xiàn)一個掃雷小游戲

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

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

一、全部源碼

//棋盤大小
#define ROW 9
#define COL 9
//棋盤加邊緣坐標大小
#define ROWS 10
#define COLS 10
#define EASY_COUNT 10//雷的數(shù)量
#include <stdio.h>
#include<stdlib.h>
#include<time.h>
 
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;
  }
 }
}
void DisplayBoard(char board[ROWS][COLS], int row, int col)
{
 int i = 0;
 int j = 0;
 for (i = 0; i <= row; 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 ger_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 FineMine(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, col, row);
    break;
   }
   else
   {
    int count = ger_mine_count(mine, x, y);
    show[x][y] = count + '0';
    DisplayBoard(show, col, row);
    win++;
   }
  }
  else
  {
   printf("坐標非法,重新輸入!\n");
  }
  if (win == row*col - EASY_COUNT)
  {
   printf("排雷成功!\n");
   DisplayBoard(mine, col, row);
 
  }
 }
}
 
void game()
{
 //雷的信息存儲
 //布置雷的信息
 char mine[ROWS][COLS] = {0};
 //排查雷的信息
 char show[ROWS][COLS] = {0};
 //初始化
 InitBoard(mine, ROWS, COLS, '0');
 InitBoard(show, ROWS, COLS, '*');
 //打印棋盤
 DisplayBoard(show, ROW, COL);
 //布置雷
 Setmine(mine, ROW, COL);
 //displayboard(mine, row, col);//用于測試
 //掃雷
 FineMine(mine,show, ROW, COL);
}
void menu()
{
 printf("****************************\n");
 printf("****1.play*******0.exit*****\n");
 printf("****************************\n");
}
void test()
{
 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);
}
int main()
{
 test();
 return 0;
}

大家可以先把上面的源碼放到編譯器里運行試試,大致的運行畫面如下

二、實現(xiàn)內(nèi)容

1.游戲框架

整個游戲就兩個入口,開始游戲和退出。簡單打印一個游戲菜單,并做好對應的功能接口。

void menu()
{
 printf("****************************\n");
 printf("****1.play*******0.exit*****\n");
 printf("****************************\n");
}
void test()
{
 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);
}

整個游戲的內(nèi)容全放置在game()函數(shù)中,游戲使用兩個數(shù)組來存放信息,一個用來存放雷的位置信息,不顯示給用戶,一個用來存放用戶掃雷過程的顯示信息。整個過程就是,初始化兩個數(shù)組,再重復執(zhí)行用戶掃雷的操作,直到用戶掃雷成功或者失敗停止,跳回菜單界面。

void game()
{
 //雷的信息存儲
 //布置雷的信息
 char mine[ROWS][COLS] = {0};
 //排查雷的信息
 char show[ROWS][COLS] = {0};
 //初始化
 InitBoard(mine, ROWS, COLS, '0');
 InitBoard(show, ROWS, COLS, '*');
 //打印棋盤
 DisplayBoard(show, ROW, COL);
 //布置雷
 Setmine(mine, ROW, COL);
 //displayboard(mine, row, col);//用于測試
 //掃雷
 FineMine(mine,show, ROW, COL);
}

2.具體函數(shù)實現(xiàn)

初始化,打印棋盤和布置雷,都是對數(shù)組設置循環(huán)進行操作即可。雷的設置上可設置好時間種子,利用隨機函數(shù)來布置雷。

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;
  }
 }
}
void DisplayBoard(char board[ROWS][COLS], int row, int col)
{
 int i = 0;
 int j = 0;
 for (i = 0; i <= row; 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--;
  }
 }
}

掃雷的過程是這個游戲程序設計的難點。我們都知道,掃雷中掃過一個位置這個位置會顯示一個數(shù)字表示周圍雷的個數(shù)。于是可以寫一個函數(shù)來獲得周圍雷的信息。由于再數(shù)組中使用1表示雷0表示沒有雷,于是將周圍的八個位置存儲內(nèi)容-8*字符0,根據(jù)ASCII碼值可獲得雷的個數(shù)。對游戲結果的判定,可根據(jù)訪問的數(shù)組內(nèi)容是否是雷的標志來判定用戶是否踩雷,以及使用計數(shù)變量判斷棋盤是否已經(jīng)沒有非雷位,用戶掃雷成功。

int ger_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 FineMine(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, col, row);
    break;
   }
   else
   {
    int count = ger_mine_count(mine, x, y);
    show[x][y] = count + '0';
    DisplayBoard(show, col, row);
    win++;
   }
  }
  else
  {
   printf("坐標非法,重新輸入!\n");
  }
  if (win == row*col - EASY_COUNT)
  {
   printf("排雷成功!\n");
   DisplayBoard(mine, col, row);
 
  }
 }
}

總結

以上就是全部內(nèi)容了,使用簡單的數(shù)組知識就可以實現(xiàn)你自己的掃雷小游戲了,快去試試吧。

相關文章

  • C語言切割多層字符串(strtok_r strtok使用方法)

    C語言切割多層字符串(strtok_r strtok使用方法)

    這篇文章主要介紹了C語言切割多層字符串的方法,說了strtok的弱點,使用strtok_r的方法
    2013-11-11
  • C語言計算代碼執(zhí)行所耗CPU時鐘周期

    C語言計算代碼執(zhí)行所耗CPU時鐘周期

    本文給大家介紹的是使用C語言來計算代碼執(zhí)行所耗CPU時鐘周期的代碼,非常的簡單實用,不過要依托于sync,有需要的小伙伴自己參考下吧。
    2015-03-03
  • 從C語言過渡到C++之基本變化

    從C語言過渡到C++之基本變化

    在之前的C++代碼訓練營系列中,我試圖用完成具體項目的方式給大家介紹C++,但后來大家反饋說這樣從C過渡到C++有點跟不上。于是我又專門設計了這個《從C到C++》的過渡專題,我準備通過10篇文章介紹一下C++和C的重要區(qū)別。
    2017-07-07
  • C++形參與實參的區(qū)別實例解析

    C++形參與實參的區(qū)別實例解析

    這篇文章主要介紹了C++形參與實參的區(qū)別實例解析,需要的朋友可以參考下
    2014-07-07
  • C/C++堆區(qū)專篇精講

    C/C++堆區(qū)專篇精講

    一直以來總是對這個問題的認識比較朦朧,我相信很多朋友也是這樣的,總是聽到內(nèi)存一會在棧上分配,一會又在堆上分配,那么它們之間到底是怎么的區(qū)別呢,讓我們一起來看看
    2022-10-10
  • 解析C++編程中的繼承方面的運用

    解析C++編程中的繼承方面的運用

    這篇文章主要介紹了解析C++編程中的繼承方面的運用,是C++入門學習中的基礎知識,需要的朋友可以參考下
    2015-09-09
  • 用C語言求解一元二次方程的簡單實現(xiàn)

    用C語言求解一元二次方程的簡單實現(xiàn)

    這篇文章主要介紹了用C語言求解一元二次方程的簡單實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • C++實現(xiàn)模擬shell命令行(代碼解析)

    C++實現(xiàn)模擬shell命令行(代碼解析)

    這篇文章主要介紹了C++實現(xiàn)模擬shell命令行,本文通過實例代碼進行命令行解析,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12
  • C語言分支循環(huán)其嵌套語句的使用

    C語言分支循環(huán)其嵌套語句的使用

    本文主要介紹了switch 嵌套和循環(huán)嵌套,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • C++中的菱形繼承深入分析

    C++中的菱形繼承深入分析

    這篇文章主要介紹了C++中的菱形繼承深入分析的相關資料,需要的朋友可以參考下
    2017-07-07

最新評論