C语言实现扫雷小游戏

 更新时间:2020年03月30日 16:38:01   作者:Stephen_curry_66  
这篇文章主要为大家详细介绍了C语言实现扫雷小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言实现扫雷游戏的具体代码,供大家参考,具体内容如下

主函数:main.c

#include "game.h"
void Menu()
{
  printf("##########################\n");
  printf("##1.play 0.exit##########\n");
  printf("##########################\n");
  printf("## Please Enter select! ##\n");
}
 
int main()
{
  Menu();
  srand((unsigned int)time(NULL));
  int quit = 0;
  while (!quit)
  {
   int select = 0;
   printf("请输入你的选择:\n");
   scanf("%d", &select);
   switch (select)
   {
   case 1:
   game();
   break;
   case 2:
   quit = 1;
   break;
   default :
   printf("你输入有误,请重新输入:\n");
   break;
   }
  }
  printf("Bye Bye!\n");
  system("pause");
  return 0;
}

子函数:game.c

#include "game.h"
void game()
{ 
 char mine[ROWS][COLS] = { 0 }; 
 char show[ROWS][COLS] = { 0 }; 
 memset(mine, '0', sizeof(mine));//初始化数组置为0
 memset(show, '*', sizeof(show));//初始化数组置为* 
 int no_y, no_x; 
 set_mine(mine,ROWS,COLS,&no_x,&no_y);//布雷 ‘1'表示雷 
 int x = 0; 
 int y = 0; 
 int time = 100 - NUM; 
 while (time > 0) 
 { 
 system("cls");//清屏 
 Show(show, ROWS, COLS);//打印 棋盘 
 printf("请输入坐标:\n"); 
 scanf("%d%d", &x, &y); 
 if (x<1 || x>10 || y<1 || y>10) 
 { 
 printf("你输入有误,请重新输入:\n"); 
 continue; 
 } 
 if (show[x][y] != '*') 
 { 
 printf("你输入有误,请重新输入:\n"); 
 continue; 
 } 
 if (mine[x][y] == '1') 
 { 
 if (time == 80)//如果第一次有雷,用一个没雷的与这个交换 
 { 
 mine[x][y] = '0'; 
 mine[no_y][no_y] = '1'; 
 } 
 else 
 { 
 printf("game over!\n"); 
 Show(mine, ROWS, COLS); 
 break; 
 } 
 } 
 show[x][y] = get_mine_count(mine, x, y) + '0';
 Expand(mine, show, x, y);
 time--; 
 }

}
void set_mine(char mine[ROWS][COLS],int col,int row,int *no_x,int *no_y)//声明布雷函数
{ 
 int count = NUM;//设置计数器,统计布雷的个数
 while (count > 0) 
 { 
 int x = rand() % (col-2) + 1; 
 int y = rand() % (col-2) + 1; 
 if ((mine[x][y]) == '0') 
 { 
 mine[x][y] = '1'; 
 count--; 
 } 
 } 
 for (int i = 1; i <= 10; i++) 
 { 
 for (int j = 1; i <= 10; j++) 
 { 
 if (mine[i][j] == '0') 
 { 
 no_x = i; 
 no_y = j; 
 return; 
 } 
 } 
 }
}
void Show(char mine[ROWS][COLS], int row, int col)//声明打印棋盘函数
{ 
 int i = 0; 
 int j = 0; 
 printf(" ");
 for (i = 1; i <= 10 ; i++) 
 { 
 printf("%2d |", i); 
 } 
 printf("\n"); 
 for (i = 1; i <= 11; i++) 
 { 
 printf("----"); 
 } 
 printf("\n"); 
 for (i = 1; i <= 10 ; i++) 
 { 
 printf("%2d |", i); 
 for (j = 1; j <= 10; j++) 
 { 
 printf("%2c |", mine[i][j]); 
 } 
 printf("\n"); 
 for (int i = 1; i <= 11; i++) 
 { 
 printf("----"); 
 } 
 printf("\n"); 
 }
}
int get_mine_count(char mine[ROWS][COLS], int x, int y)//雷数统计
{ 
 return 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]+ mine[x - 1][y] - 8 * '0';
}
void Expand(char mine[ROWS][COLS], char show[ROWS][COLS], int x, int y)
{ 
 if (x >= 1 && x <= 10 && y >= 1 && y <= 10) 
 { 
 if (get_mine_count(mine, x, y) + '0' == '0') //表示x,y周围没雷 
 { 
 show[x][y] = '0'; 
 if (show[x - 1][y - 1] == '*') 
 { 
 Expand(mine, show, x - 1, y - 1); 
 } 
 if (show[x - 1][y] == '*') 
 { 
 Expand(mine, show, x - 1, y ); 
 } 
 if (show[x - 1][y + 1] == '*') 
 { 
 Expand(mine, show, x - 1, y + 1); 
 } 
 if (show[x ][y - 1] == '*') 
 { 
 Expand(mine, show, x , y - 1); 
 } 
 if (show[x][y + 1] == '*') 
 { 
 Expand(mine, show, x , y + 1); 
 } 
 if (show[x + 1][y - 1] == '*') 
 { 
 Expand(mine, show, x + 1, y - 1); 
 } 
 if (show[x + 1][y] == '*') 
 { 
 Expand(mine, show, x + 1, y ); 
 } 
 if (show[x + 1][y + 1] == '*') 
 { 
 Expand(mine, show, x + 1, y + 1); 
 } 
 } 
 }
}

函数声明:game.h

#ifndef _GAME_H_
#define _GAME_H_
#include<stdio.h>
#include<Windows.h>
#pragma warning(disable:4996)
#include<time.h>
#include<string.h>

#define ROWS 12
#define COLS 12

#define NUM 20 //雷数
  
 
void game();
void set_mine(char mine[ROWS][COLS],int row, int col, int *no_x, int *no_y);
void Show(char mine[ROWS][COLS], int row, int col);
int get_mine_count(char mine[ROWS][COLS], int x, int y);
void Expand(char mine[ROWS][COLS], char show[ROWS][COLS], int x, int y);
 
#endif

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

相关文章

  • C语言深入探索动态内存分配的使用

    C语言深入探索动态内存分配的使用

    给数组分配多大的空间?你是否和初学C时的我一样,有过这样的疑问。这一期就来聊一聊动态内存的分配,读完这篇文章,你可能对内存的分配有一个更好的理解
    2022-04-04
  • 利用C++简单实现顺序表和单链表的示例代码

    利用C++简单实现顺序表和单链表的示例代码

    这篇文章主要给大家介绍了关于利用C++简单实现顺序表和单链表的方法,文中给出了详细的示例代码供大家参考学习,需要的朋友可以参考借鉴,下面来跟着小编一起来学习学习吧。
    2017-08-08
  • C/C++字符串与数字互转的实现

    C/C++字符串与数字互转的实现

    这篇文章主要介绍了C/C++字符串与数字互转的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-01-01
  • C++中回调函数(CallBack)的用法分析

    C++中回调函数(CallBack)的用法分析

    这篇文章主要介绍了C++中回调函数(CallBack)的用法,较为详细的分析了C++中回调函数(CallBack)的原理并以实例形式总结了其具体用法,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-01-01
  • C++快速幂与大数取模算法示例

    C++快速幂与大数取模算法示例

    这篇文章主要介绍了C++快速幂算法和大数取模算法的示例,对C++程序员来说有一定的帮助,有需要的朋友可以参考借鉴,下面来一起看看。
    2016-08-08
  • OpenCV实现拼图算法

    OpenCV实现拼图算法

    这篇文章主要为大家详细介绍了OpenCV实现拼图算法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • C++ 栈和队列的实现超详细解析

    C++ 栈和队列的实现超详细解析

    栈和队列,严格意义上来说,也属于线性表,因为它们也都用于存储逻辑关系为 "一对一" 的数据,但由于它们比较特殊,因此将其单独作为一章,做重点讲解
    2022-03-03
  • Matlab利用prim算法实现迷宫的生成

    Matlab利用prim算法实现迷宫的生成

    普里姆算法(Prim算法),图论中的一种算法,可在加权连通图里搜索最小生成树。本文将利用prim算法迷宫生成及其艺术渲染,感兴趣的可以了解一下
    2022-10-10
  • 详解C/C++内存区域划分(简而易懂)

    详解C/C++内存区域划分(简而易懂)

    C/C++中,内存主要分为、堆、栈、全局/静态存储区和常量存储区。本文重点给大家介绍C/C++内存区域划分的相关知识,需要的朋友参考下吧
    2021-06-06
  • C++的指针,引用和STL详解

    C++的指针,引用和STL详解

    这篇文章主要为大家详细介绍了C++的指针,引用和STL,使用数据库,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02

最新评论