基于C语言实现扫雷游戏

扫雷游戏和我上面写的三子棋游戏的框架有类似,对与这种像对于来说比较复杂一点的代码。我们就应该应用同样的思路,先构建好一个框架,理清自己的思路,然后再编写代码

1.首先,对于扫雷游戏,我们应该创建两个二维数组,一个是给玩家看到的,另一个应该是含有雷到底在哪里的一个二维数组,只有一个是完全不够的.

2.把玩家能看到的那张表打印出来

3.让玩家输入要下的坐标,并且对其要进行校验

4.判断是否有地雷,有则游戏直接结束

5.如果没有错误,则将周围手雷的数目打在屏幕上

6.判断输赢,看翻开格子的数量如果是71=9*9-10

7.如果翻开的格子数为71,则游戏结束,玩家胜利

思路一样,主要就是根据自己列出的思路去合理的写出代码,就好啦

如下面例题:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#define MAX_COL 9           //宏定义
#define MAX_ROW 9
#define DEFAULT_MINE_COUNT 10     //宏定义一个10个雷

//扫雷游戏
//1.创建两个二维数组并进行初始化
//2.打印一张地图
//3.玩家输入要读取的坐标,并对玩家输入的坐标进行校验
//4.判断输入的坐标是否有地雷,如果存在,则直接游戏结束
//5.如果没有,则统计周围雷的数目并将其显示在屏幕上
//6.判断输赢,并检查翻开格子的数量,9*9-10=71;
//7.如果将71个格子全部翻开,则游戏结束,玩家胜利

int menu(){      //菜单显示
 printf("\n\n=======================\n");
 printf("1.开始游戏\n");
 printf("2.结束游戏\n");
 printf("=======================\n");
 printf("请输入序号:");
 int choice = 0;
 scanf("%d",&choice);
 return choice;
}
void init(char showMap[MAX_ROW][MAX_COL], char mineMap[MAX_ROW][MAX_COL]){  //对这两个二维数组进行赋初值,并将其改变所存放的数
 for (int row = 0; row < MAX_ROW; row++){      //for嵌套(二维数组)
 for (int col = 0; col < MAX_COL; col++){
  showMap[row][col] = '*';
 }
 }
 for (int row = 0; row <MAX_ROW; row++){
 for (int col = 0; col <MAX_COL; col++){
  mineMap[row][col] = '0';
 }
 }
 int n = DEFAULT_MINE_COUNT;            //将雷赋值给n
 while(n > 0){                   //循环并让电脑取随机数
 int row = rand() % MAX_ROW;
  int col = rand() % MAX_COL;
 if (mineMap[row][col] == '1'){    //遇到雷
  continue;
 }
 mineMap[row][col] = '1';
  n--;        //逐次递减,保证只有10个雷
 }
}
void printMap(char theMap[MAX_ROW][MAX_COL]){     //这个是玩家能看到的界面
 printf("1 2 3 4 5 6 7 8 9\n");
 printf("-----------------\n");
 for (int row = 0; row < MAX_ROW; row++){
 for (int col = 0; col < MAX_COL; col++){
  printf("%c ",theMap[row][col]);
 }
 printf("\n");
 }
 printf("-----------------\n");

}
void updateShowMap(char showMap[MAX_ROW][MAX_COL],   //让在翻开的格子上显示周围8个格子有雷的数目
 char mineMap[MAX_ROW][MAX_COL],int row, int col){
 int count = 0;
 for (int r = row - 1; r<= row + 1; r++){
 for (int c = col - 1; c <= col + 1; c++){
  if (r < 0 || r >= MAX_ROW || c < 0 || c >= MAX_COL){  //校验,让其在给定范围内
  continue;
  }
  if (mineMap[r][c] == '1'){         //周围有,则++
  count++;
  }
 }
 }
 showMap[row][col] = count + '0';        //将其转换为10进制
}

void game(){

 char showMap[MAX_ROW][MAX_COL] = { 0 };    //定义二维数组
 char mineMap[MAX_ROW][MAX_COL] = { 0 };
 init(showMap, mineMap);            //1.对两个二维数组进行赋初值,定义
 int openedBlockCount = 0;
 while (1){

 printMap(showMap);     //2.将图显示出来
 int row = 0;
 int col = 0;
 printf("请输入你要翻开的坐标(row,col):");
 scanf("%d %d",&row, &col);    //赋予地址
 if (row < 0 || row >= MAX_ROW || col < 0 || col >= MAX_COL){ //这里是对函数的校验
  printf("您输入的坐标有误!\n");
  continue;
 }
 if (showMap[row][col] != '*'){       //错误提醒
  printf("当前位置已经被翻开!\n");
  continue;
 }
 if (mineMap[row][col] == '1'){       //遇到雷时,游戏结束
  printf("Game over!\n");
  printMap(mineMap);    //并且打印mineMap()
  break;
 }
      updateShowMap( showMap, mineMap, row, col);       //将周围雷的数目显示在屏幕上
  openedBlockCount++;           //已经被翻开的格子的数目
  if (openedBlockCount == MAX_ROW*MAX_COL - DEFAULT_MINE_COUNT){  //翻开格子数目71,则玩家胜利
  printf("游戏胜利了!;");
  printMap(mineMap);         //打印雷图
  break;
  }
 }
}

int main(){
 while (1){
 int choice = menu();   //创建菜单
 if (choice == 1){
  game();    //并在choice=1时调用game()函数
 }else if (choice == 0){
  printf("Goodbye!");
  break;
 }else{
  printf("您的输入有误");
 }
 }
 system("pause");
 return 0;
}

写这个代码的时候还是要小心,要细心,尤其是在row<=MAX_ROW这一部分的时候,一定要细心,早上我也调试了好久,就是因为多加了等于号,累了大半天,还是要多敲代码。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 基于C语言实现的扫雷游戏代码

    本文详细讲述了基于C语言实现的扫雷游戏代码,代码中备有比较详细的注释,便于读者阅读和理解.希望对学习游戏开发的朋友能有一点借鉴价值. 完整的实例代码如下: /* 模拟扫雷游戏 */ #include <graphics.h> #include <math.h> #include <stdio.h> #include <dos.h> #include <stdlib.h> #include <conio.h> #include <

  • C语言 扫雷程序的实现

    C语言 扫雷程序的实现 这个游戏可以实现根据选择坐标后所显示无雷区范围的不同分为简单 ,普通和困难 游戏程序中,实现了游戏的计时(分钟)功能,实现了扫雷游戏的最基础功能. 定义了一个9*9的棋盘,玩家只要根据提示选择游戏,和难度: 根据提示输入 合法的坐标,如输入不合法则会进行提示: 扫雷结束则会提示:如触雷则游戏自动结束: 整个游戏设计中主要的函数为: 1.初始化地雷棋盘和显示棋盘 2.棋盘打印函数 3.扫雷函数的实现 4.游戏主函数 大家可以在宏定义中改变棋盘大小,雷的个数,以及显示的无雷区

  • C语言实现简易版扫雷小游戏

    本文实例为大家分享了C语言实现简易版扫雷的具体代码,供大家参考,具体内容如下 声明 本次扫雷小游戏用多文件来编写.首先,要自定义的一个头文件 mine.h,里面有扫雷程序里面所需要的头文件.常量和所有函数的声明.其次,创建主函数 test.c,用自己喜欢的方式构建一个游戏的框架,最后,创建自定义函数 mine.c,编写各项功能. 设计思路 1.先写主函数,理清整个游戏流程. int main() { int quit = 0; do{ int select = 0; Menu(); scanf(

  • C语言实现简易扫雷游戏

    本文实例为大家分享了C语言实现简易扫雷游戏的具体代码,供大家参考,具体内容如下 扫雷 楔子: 扫雷游戏是我们小时候无聊时消磨时间的小玩意,虽然更新到Win10系统后经典的扫雷游戏不再了,不过它现在仍以一种抓虫子的游戏形式存在于Windows这个系统平台,不禁感慨游戏还是那个游戏,不过人已经不是那些人了啊. 其实扫雷游戏的实现也主要运用了数组和函数封装与调用的知识,具体请看程序. 以下为程序主体: #define _CRT_SECURE_NO_WARNINGS #include <stdio.h>

  • C语言实现扫雷小游戏(适合初学者)

    扫雷小游戏作为初学c语言的小白有很大的帮助,其中用到了函数的定义,函数的声明,循环语句,数组思想等等知识,对于代码理解和设计代码思路有很大的帮助,本文就详细介绍了代码的各个步骤和运行结果.希望给到和我一样的小白一点帮助. //game.h头文件 #include<stdio.h> #include<stdlib.h> #include<time.h> #define ROW 9//定义了界面的长宽,可以直更改ROW,COL的值,避免了程序中数字重复出现 #define

  • C语言简单实现扫雷小游戏

    本文实例为大家分享了C语言简单实现扫雷小游戏 的具体代码,供大家参考,具体内容如下 游戏规则: 以9*9棋盘为例,棋盘上随机分布着10个地雷,玩家在棋盘上进行点击,如果被点击的格子是地雷,则玩家被炸"死",游戏结束:如果被点击的格子上没有地雷,与被点击的格子相邻的格子(被点击格子的上下左右还有斜向,共八个格子)有地雷,则在被点击的格子上显示这些地雷的总数,如果与被点击的格子相邻的八个格子都没有地雷,则棋盘自动展开,直到与展开的格子相邻的格子有地雷才停止.此时最后被展开的格子显示其相邻格

  • C语言扫雷游戏的实现代码

    这是一个用C语言实现的控制台扫雷小游戏,实现了随机布置炸弹.扫描炸弹.标记炸弹.百分百第一次不被炸死等功能. 编译器:vs2015 功能模块图 源代码 #include<stdio.h> #include<stdlib.h> #include<time.h> void show(int cbd[10][10],int u[10][10]) //界面输出函数 { int i, j; //for (i = 0; i < 10; i++) //输出全部炸弹信息(上帝视角

  • C语言实现扫雷游戏(初级版)

    本文实例为大家分享了C语言实现扫雷游戏的具体代码,供大家参考,具体内容如下 game.h #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 10 //初始化棋盘 void InitBoard(char board[ROWS][COLS], int rows,

  • C语言实现简单的扫雷小游戏

    本文实例为大家分享了C语言实现扫雷小游戏的具体代码,供大家参考,具体内容如下 在编写扫雷小游戏之前,第一,我们应该列出我们想要实现的扫雷小游戏的功能: 1.显示选中的坐标周围的雷的个数. 2.保证第一次选中的坐标不是雷. 3.选中的坐标周围8个格子中没有雷,则展开. 第二,我们应该明白我们需要两个棋盘来实现扫雷游戏:一个棋盘用来展示给玩家,初始界面全为" * " (未翻开的格子),这个页面就是我们常见的扫雷页面.另一个棋盘用来给编写者看,棋盘内只有字符'1'和字符'0' .'1'代表雷

  • C语言开发简易版扫雷小游戏

    前言: 想起来做这个是因为那时候某天知道了原来黑框框里面的光标是可以控制的,而且又经常听人说起这个,就锻炼一下好了. 之前就完成了那1.0的版本,现在想放上来分享却发现有蛮多问题的,而且最重要的是没什么注释[果然那时候太年轻]!现在看了也是被那时候的自己逗笑了,就修改了一些小bug,增加了算是详尽而清楚的注释,嗯,MSDN上面对各种函数的解释很详细的[又锻炼一下英语],顺便让开头和结尾的展示"动"了起来,就当作1.5的版本好了. 这个只是给出了一个实现的思路,其中肯定也有很多不合理的地

随机推荐