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. 【转】Spring面试问题集锦

    Q. 对于依赖倒置原则(Dependency Inversion Principle,DIP),依赖注入(Dependency Injection,DI)和控制反转(Inversion of Cont ...

  2. Java控制台五子棋(纯算法)

    Java五子棋小游戏 本方案是基于控制台写的一个代码 没有花里胡哨的界面,只为研究算法 仅仅用了200行代码 下面是的是运行结果 游戏运行结果 这里我就很简单的复制了一个结果 第9回合,下子方:玩家2 ...

  3. react入门(六):状态提升&context上下文小白速懂

    一.状态提升 使用 react 经常会遇到几个组件需要共用状态数据的情况.这种情况下,我们最好将这部分共享的状态提升至他们最近的父组件当中进行管理. 原理:父组件基于属性把自己的一个fn函数传递给子组 ...

  4. 揭秘webpack plugin

    前言 Plugin(插件) 是 webpack 生态的的一个关键部分.它为社区提供了一种强大的方法来扩展 webpack 和开发 webpack 的编译过程.这篇文章将尝试探索 webpack plu ...

  5. 用来更新服务的bat 脚本

    net stop XK.Service echo "已停止服务,开始更新!" set /a t = echo %t% :loop 127.1 >nul set /a t = ...

  6. 完美解决win10系统无法安装.NET Framework问题

    今天在安装willow插件的时候系统提示需要安装.NET Framework3.5的问题,当点击系统自动解决的时候,Windows系统又会提示错误,其实这也见怪不怪了,如果能自动解决的话也不会出现这种 ...

  7. Activiti 启动事件(Start Event)

    Activiti 启动事件(Start Event) 作者:Jesai 生活里,没有容易二字,忧伤是一种本能,而微笑是一种能力 版权所有,未经允许,禁止引用.如需引用,请注明出处. 前言: 启动事件是 ...

  8. Activiti接受任务(receiveTask)

    Activiti接受任务(receiveTask) 作者:Jesai 前言: Activiti接受任务(receiveTask)其实和Activiti的手动任务是差不多的,不过手动任务是直接通过,而A ...

  9. 【Flink】Flink作业调度流程分析

    1. 概述 当向Flink集群提交用户作业时,从用户角度看,只需要作业处理逻辑正确,输出正确的结果即可:而不用关心作业何时被调度的,作业申请的资源又是如何被分配的以及作业何时会结束:但是了解作业在运行 ...

  10. .net core ef动态orderby

    前言 最近在给大家写一套开源的.net core权限管理框架.现在已经写到前台UI + 后台动态查询的部分. 发现需要动态orderby但是网上没有现成的例子 二话不说上代码 建议namespace ...