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

C語言實現(xiàn)簡易掃雷程序

 更新時間:2021年07月30日 10:08:41   作者:往明  
這篇文章主要為大家詳細介紹了C語言實現(xiàn)簡易掃雷程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

前言

前面寫了三子棋的小游戲,感覺不過癮,今天再來一個掃雷的小游戲。歡迎評論探討

思路分析

游戲簡介

說到掃雷很容易想起很多個方形格子,表面什么也沒有,點擊其中一個小格子,如果時炸彈,游戲直接,如果沒有炸彈,則顯示周圍八個格子中炸彈個數(shù),看到這里,我們需要棋盤,即二維數(shù)組,看來還需要兩個,一個放炸彈坐標,一個用來反饋周圍炸彈數(shù)

棋盤設(shè)置

有了前面三子棋的基礎(chǔ)我們首先要初始化棋盤并且可以打印棋盤,這個好像沒有什么難度。

我們用*代表未知,這是一個9的方陣,但是好像用了11X11的數(shù)組,這是避免計算點擊邊界的時候出現(xiàn)數(shù)組越界的情況。

炸彈設(shè)置

我們需要一個函數(shù)來設(shè)置炸彈,并且保證它是隨機,且不能占用已經(jīng)設(shè)置的炸彈位置,我們將炸彈設(shè)置為1,非炸彈設(shè)置為0,方便計算周圍砸蛋數(shù)。

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

玩家操作

初始化棋盤->生成炸彈->玩家點擊->判斷炸彈或者周圍炸彈數(shù)->玩家點擊->判斷炸彈或者周圍炸彈數(shù)
同時還要記錄操作次數(shù),如果操作數(shù)等于格子總數(shù)減去炸彈數(shù)就贏了,點擊炸彈直接over。

運行游戲

首先排查1,1,但是沒有炸彈,接著隨機排查幾個坐標

到此,我們可以推斷4,2是一個炸彈

被炸死后,顯示所有炸彈的未知。
選擇0,1是為了方便反饋周圍炸彈數(shù)量。

源代碼

本次程序采用多文件形式

game.h

#pragma once

#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);

game.c

#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);
 }
}

test.c

#define _CRT_SECURE_NO_WARNINGS
#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;
}

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

相關(guān)文章

  • strtok函數(shù)的使用示例

    strtok函數(shù)的使用示例

    今天小編就為大家分享一篇關(guān)于strtok函數(shù)的使用示例,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • C++ 中隨機函數(shù)random函數(shù)的使用方法

    C++ 中隨機函數(shù)random函數(shù)的使用方法

    這篇文章主要介紹了C++ 中隨機函數(shù)random函數(shù)的使用方法的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下
    2017-09-09
  • C語言中的參數(shù)傳遞機制詳解

    C語言中的參數(shù)傳遞機制詳解

    這篇文章主要介紹了C語言中的參數(shù)傳遞機制,C語言中函數(shù)參數(shù)的傳遞有:值傳遞、地址傳遞、引用傳遞這三種形式。下面我們詳細探討下
    2017-04-04
  • C++中內(nèi)存池的簡單原理及實現(xiàn)詳解

    C++中內(nèi)存池的簡單原理及實現(xiàn)詳解

    內(nèi)存池的思想是,在真正使用內(nèi)存之前,預(yù)先申請分配一定數(shù)量、大小預(yù)設(shè)的內(nèi)存塊留作備用。本文主要來和大家聊聊內(nèi)存池的簡單原理及實現(xiàn),希望對大家有所幫助
    2023-03-03
  • 使用matlab繪制七夕表白玫瑰花束

    使用matlab繪制七夕表白玫瑰花束

    又是一年七夕節(jié)要到了,每年一次直男審美MATLAB繪圖大賽開始了,于是今年對我之前寫的老代碼進行了點優(yōu)化組合,整了個花球變花束,感興趣的小伙伴可以動手試一試
    2023-08-08
  • C++實現(xiàn)神經(jīng)BP神經(jīng)網(wǎng)絡(luò)

    C++實現(xiàn)神經(jīng)BP神經(jīng)網(wǎng)絡(luò)

    這篇文章主要為大家詳細介紹了C++實現(xiàn)神經(jīng)BP神經(jīng)網(wǎng)絡(luò),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • 大數(shù)(高精度數(shù))模板(分享)

    大數(shù)(高精度數(shù))模板(分享)

    本篇文章對大數(shù)(高精度數(shù))模板進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • 一文帶你了解C++中的字符替換方法

    一文帶你了解C++中的字符替換方法

    這篇文章主要為大家詳細介紹了C++中常用的幾個字符替換方法,文中的示例代碼講解詳細,具有一定的學(xué)習(xí)價值,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-04-04
  • C語言回溯法解八皇后問題(八皇后算法)

    C語言回溯法解八皇后問題(八皇后算法)

    這篇文章介紹了C語言回溯法解八皇后問題,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12
  • C++ map的簡單使用實現(xiàn)

    C++ map的簡單使用實現(xiàn)

    map是STL的一個關(guān)聯(lián)容器,它以<key,value>一對一的形式存儲,且map的內(nèi)部自建一個紅黑樹,使得其可以自動排序,本文就介紹一下C++ map的簡單使用,感興趣的可以了解一下
    2021-05-05

最新評論