C语言-扫雷游戏

本文将对此游戏做一个大致的概述,此代码适合初学者,编写软件使用了vs2017。

该代码可以实现如下功能:

1.用户可以选择3个难度,分别布置不同个数的雷。

2.随机数设置雷的位置。

3.输入坐标进行排雷(周围没有雷可以展开一片,用0表示)。

4.输入的坐标为雷时,被炸死游戏结束。

5.排除所有的雷后,游戏结束,显示所用时间。

下面展示源代码:

头文件game.h

引用了几个必要的头文件,宏定义了行和列以及雷的个数,方便后续的更改。

 #define _CRT_SECURE_NO_WARNINGS 1

 #include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<windows.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 mine[ROWS][COLS], int row, int col,int count);
void findmine(char mine[ROWS][COLS],char show[ROWS][COLS],int row,int col,int count);

测试模块 text.c

本模块主要针对于控制台窗口的颜色与大小,以及函数的调用。

#define _CRT_SECURE_NO_WARNINGS 1

#include"game.h"
void menu()
{ printf("***********************************\n");
printf("***************1.play**************\n");
printf("***************0.exit**************\n");
printf("***********************************\n"); }
void game()
{
int input = 0;
printf("请选择难度:\n1.简单\n2.困难\n3.炼狱\n");
scanf("%d", &input);
int count = input * EASY_COUNT;
//sprintf(stCmd, "mode con cols=%d lines=%d", a,b);
//system(stCmd);
char mine[ROWS][COLS];//存放雷的信息
char show[ROWS][COLS];//存放排查出的雷的信息
Initboard(mine, ROWS, COLS,'0'); //'0'
Initboard(show, ROWS, COLS,'*');//'*'
//displayboard(mine, ROW, COL);
setmine(mine, ROW, COL,count);
//displayboard(mine, ROW, COL);
displayboard(show, ROW, COL);
findmine(mine, show, ROW, COL,count);
}
void test()
{
srand((unsigned int)time(NULL));
int input = 0;
do
{
menu();
printf("\n请选择:\n");
scanf("%d", &input);
switch (input) {
case 1:game(); break;
case 0:printf("退出游戏\n"); break;
default:printf("输入有误,请重新输入\n"); break;
}
} while (input); } int main()
{
int a = 35; int b = 16;
char stCmd[128];
system("color 4A");
system("mode con: cols=30 lines=12");
printf("\n\n\n-----欢迎进入扫雷游戏-----\n\n\n");
printf("----------请稍后----------\n\n\n");
Sleep(1000);
system("cls");
system("color 1A");
sprintf(stCmd, "mode con cols=%d lines=%d", a, b);
system(stCmd);
test();
return 0;
}

  游戏模块 game.c

此模块为各个函数的实现。

#define _CRT_SECURE_NO_WARNINGS 1

#include"game.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 show[ROWS][COLS], int row, int col)
{ int i = 0;
int j = 0;
printf("\n ");
for(i=0;i<=row;i++)
{
printf("%d ", i);
}
printf("\n");
printf(" ===========================\n");
for (i = 1; i <=row; i++)
{
printf("%d ||", i);
for (j = 1; j <= col; j++)
{
printf("%c ",show[i][j]);
}
printf("||");
printf("\n");
}
printf(" ============================\n"); }
void setmine(char mine[ROWS][COLS], int row, int col,int count)
{ system("cls");
while (count)
{
int x = rand() % row + 1;
int y = rand() % col + 1;
if (mine[x][y] == '0')
{
mine[x][y] = '0'+1;
count--;
} } }
static int judgemine(char mine[ROWS][COLS], int x,int y,int* count1)
{
(*count1)--;
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 Recursion(char mine[ROWS][COLS], char show[ROWS][COLS], int x, int y, int *count1)
{
int res = judgemine(mine, x, y, count1);
if (res == 0 && show[x][y] == '*')
{
show[x][y] = '0';
int arr[8][2] = { {-1,-1},{-1,0},{-1,1},{0,-1},{0,1},{1,-1},{1,0},{1,1} };
for (int i = 0; i < 8; ++i)
{
if (x + arr[i][0] >= 1 && x + arr[i][0] <= ROW && y + arr[i][1] >= 1 && y + arr[i][1] <= COL
&& show[x + arr[i][0]][y + arr[i][1]] == '*')
Recursion(mine, show, x + arr[i][0], y + arr[i][1], count1);
}
}
else
show[x][y] = res + '0';
} void findmine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col,int count)
{
int x = 0;
int y = 0;
int count1 = ROW * COL-count;
time_t start, end;
start = time(NULL);
while (count1)
{ printf("请输入要排查的坐标:\n");
scanf("%d %d", &x, &y);
system("cls");
if (show[x][y] != '*')
{
printf("此坐标已经排查过,请重新输入!\n");
displayboard(show, ROW, COL);
continue;
}
if (x >= 1 && x <= row && y >= 1 && y <= col)
{
if (mine[x][y] == '0' + 1)
{
printf("很遗憾,你被炸死了\n");
displayboard(mine, ROW, COL);
break;
}
else
{
Recursion(mine, show, x, y, &count1);
//displayboard(mine, ROW, COL);
displayboard(show, ROW, COL); }
}
else
{
printf("输入有误,请重新输入\n"); }end = time(NULL); } if (count1 == 0)
{
printf("恭喜你排雷成功!\n"); printf("用时:%d秒\n", (int)difftime(end, start));
}
}

以上便为此扫雷游戏的简单完成,本文到此结束谢谢!

c语言小游戏-扫雷的完成的更多相关文章

  1. 【C语言探索之旅】 第一部分第八课:第一个C语言小游戏

    ​ 内容简介 1.课程大纲 2.第一部分第八课:第一个C语言小游戏 3.第一部分第九课预告: 函数 课程大纲 我们的课程分为四大部分,每一个部分结束后都会有练习题,并会公布答案.还会带大家用C语言编写 ...

  2. 012-C语言小游戏之推箱子

    012-C语言小游戏之推箱子 一.创建游戏地图   1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 #define ROWS 11 #define COLS 12   char ...

  3. C语言小游戏: 2048.c

    概要:2048.c是一个C语言编写的2048游戏,本文将详细分析它的源码和实现.C语言是一种经典实用的编程语言,本身也不复杂,但是学会C语言和能够编写实用的程序还是有一道鸿沟的.本文试图通过一个例子展 ...

  4. c++小游戏———扫雷

    大家好,我是芝麻狐! 这是我自制的小游戏,目前仅支持devc++. 如果你没有c++软件, 请打开网站GDB online Debugger | Compiler - Code, Compile, R ...

  5. C语言小游戏: 推箱子 支线(一)--1

    好家伙,考完试了 回顾一下2021 回顾一下某次的作业 妙啊 所以, 做一个推箱子小游戏 1.先去4399找一下关卡灵感 就它了 2.在百度上搜几篇推箱子, 参考其中的"■ ☆"图 ...

  6. c++小游戏——扫雷

    #include<cstdio> #include<cstring> #include<algorithm> #include<conio.h> #in ...

  7. C语言 小游戏之贪吃蛇

    还记得非常久曾经听群里人说做贪吃蛇什么的,那时候大一刚学了C语言,认为非常难,根本没什么思路. 前不久群里有些人又在谈论C语言贪吃蛇的事了,看着他们在做,我也打算做一个出来. 如今大三,经过了这一年半 ...

  8. C语言小游戏——2048

      2048   2048这款游戏的玩法很简单,每次可以选择上下左右滑动,每滑动一次,所有的数字方块都会往滑动的方向靠拢,系统也会在空白的地方乱数出现一个数字方块,相同数字的方块在靠拢.相撞时会相加. ...

  9. C语言小游戏:贪吃蛇

    #include <graphics.h> #include <conio.h> #include <stdio.h> #define WIDTH 40 //设置宽 ...

随机推荐

  1. Hyperledger Fabric1.4 安装

    Hyperledger Fabric 依赖的软件版本查看官方 github 地址 https://github.com/hyperledger/fabric 下文件 /docs/source/prer ...

  2. 条款03:尽可能使用const

    目录 1. 总结 2. const对象 3. const函数返回值和函数参数 4. const成员函数 const成员函数的重要性 bitwise constness logical constnes ...

  3. SQL Server2012高可用之日志传送测试

    (一)日志传送架构 (1.1)相关服务器 主服务器   :用于生产的服务器,上面运行这生产SQL Server数据库: 辅助服务器:用于存放主服务器上数据库的一个“镜像”数据库: 监控服务器:用来监控 ...

  4. 优化webpack构建时间的小技巧

    在之前工作的地方,我们一直使用webpck去构建.但是,经过长达四年的更新迭代,每个人都在同一个项目中做了不同的操作和更新,这导致我们生产构建时间达到了惊人的一分半,watch模式的rebuild也达 ...

  5. django count(*) 慢查询优化

    分页显示是web开发常见需求,随着表数据增加,200万以上时,翻页越到后面越慢,这个时候慢查询成为一个痛点,关于count(*)慢的原因,简单说会进行全表扫描,再排序,导致查询变慢.这里介绍postg ...

  6. C++ 链式继承下的虚函数列表

    目录 1.虚函数列表的位置 2.虚函数列表的内容 3.链式继承中虚函数列表的内容   注: 虚函数列表 又称为虚表, vtbl , 指向它的指针称为vptr, vs2019中称为__vfptr 操作系 ...

  7. JavaScript(1)---绑定事件、解除绑定事件

    JavaScript(1)---绑定事件.解除绑定事件 一.事件概述 1.事件的几个概念 · 事件 指的是文档或者浏览器窗口中发生的一些特定交互瞬间.我们可以通过侦听器(或者处理程序)来预定事件,以便 ...

  8. PHPStorm 最新版下载

    2019最新版phpstorm   包含其他版下载地址   https://www.jetbrains.com/phpstorm/download/other.html

  9. latex一些有用的写法

    编辑博文的时候总是忘语法,然后到网上查-- 干脆记一下! 1.编辑漂亮的函数上下标 \(\sum\limits_{i=1}^n\) 对于原有的函数:$\sum\limits_{i=1}^n$ \(\m ...

  10. 【Java并发基础】管程简介

    前言 在Java 1.5之前,Java语言提供的唯一并发语言就是管程,Java 1.5之后提供的SDK并发包也是以管程为基础的.除了Java之外,C/C++.C#等高级语言也都是支持管程的. 那么什么 ...