c语言小游戏-扫雷的完成
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语言小游戏-扫雷的完成的更多相关文章
- 【C语言探索之旅】 第一部分第八课:第一个C语言小游戏
内容简介 1.课程大纲 2.第一部分第八课:第一个C语言小游戏 3.第一部分第九课预告: 函数 课程大纲 我们的课程分为四大部分,每一个部分结束后都会有练习题,并会公布答案.还会带大家用C语言编写 ...
- 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 ...
- C语言小游戏: 2048.c
概要:2048.c是一个C语言编写的2048游戏,本文将详细分析它的源码和实现.C语言是一种经典实用的编程语言,本身也不复杂,但是学会C语言和能够编写实用的程序还是有一道鸿沟的.本文试图通过一个例子展 ...
- c++小游戏———扫雷
大家好,我是芝麻狐! 这是我自制的小游戏,目前仅支持devc++. 如果你没有c++软件, 请打开网站GDB online Debugger | Compiler - Code, Compile, R ...
- C语言小游戏: 推箱子 支线(一)--1
好家伙,考完试了 回顾一下2021 回顾一下某次的作业 妙啊 所以, 做一个推箱子小游戏 1.先去4399找一下关卡灵感 就它了 2.在百度上搜几篇推箱子, 参考其中的"■ ☆"图 ...
- c++小游戏——扫雷
#include<cstdio> #include<cstring> #include<algorithm> #include<conio.h> #in ...
- C语言 小游戏之贪吃蛇
还记得非常久曾经听群里人说做贪吃蛇什么的,那时候大一刚学了C语言,认为非常难,根本没什么思路. 前不久群里有些人又在谈论C语言贪吃蛇的事了,看着他们在做,我也打算做一个出来. 如今大三,经过了这一年半 ...
- C语言小游戏——2048
2048 2048这款游戏的玩法很简单,每次可以选择上下左右滑动,每滑动一次,所有的数字方块都会往滑动的方向靠拢,系统也会在空白的地方乱数出现一个数字方块,相同数字的方块在靠拢.相撞时会相加. ...
- C语言小游戏:贪吃蛇
#include <graphics.h> #include <conio.h> #include <stdio.h> #define WIDTH 40 //设置宽 ...
随机推荐
- Hyperledger Fabric1.4 安装
Hyperledger Fabric 依赖的软件版本查看官方 github 地址 https://github.com/hyperledger/fabric 下文件 /docs/source/prer ...
- 条款03:尽可能使用const
目录 1. 总结 2. const对象 3. const函数返回值和函数参数 4. const成员函数 const成员函数的重要性 bitwise constness logical constnes ...
- SQL Server2012高可用之日志传送测试
(一)日志传送架构 (1.1)相关服务器 主服务器 :用于生产的服务器,上面运行这生产SQL Server数据库: 辅助服务器:用于存放主服务器上数据库的一个“镜像”数据库: 监控服务器:用来监控 ...
- 优化webpack构建时间的小技巧
在之前工作的地方,我们一直使用webpck去构建.但是,经过长达四年的更新迭代,每个人都在同一个项目中做了不同的操作和更新,这导致我们生产构建时间达到了惊人的一分半,watch模式的rebuild也达 ...
- django count(*) 慢查询优化
分页显示是web开发常见需求,随着表数据增加,200万以上时,翻页越到后面越慢,这个时候慢查询成为一个痛点,关于count(*)慢的原因,简单说会进行全表扫描,再排序,导致查询变慢.这里介绍postg ...
- C++ 链式继承下的虚函数列表
目录 1.虚函数列表的位置 2.虚函数列表的内容 3.链式继承中虚函数列表的内容 注: 虚函数列表 又称为虚表, vtbl , 指向它的指针称为vptr, vs2019中称为__vfptr 操作系 ...
- JavaScript(1)---绑定事件、解除绑定事件
JavaScript(1)---绑定事件.解除绑定事件 一.事件概述 1.事件的几个概念 · 事件 指的是文档或者浏览器窗口中发生的一些特定交互瞬间.我们可以通过侦听器(或者处理程序)来预定事件,以便 ...
- PHPStorm 最新版下载
2019最新版phpstorm 包含其他版下载地址 https://www.jetbrains.com/phpstorm/download/other.html
- latex一些有用的写法
编辑博文的时候总是忘语法,然后到网上查-- 干脆记一下! 1.编辑漂亮的函数上下标 \(\sum\limits_{i=1}^n\) 对于原有的函数:$\sum\limits_{i=1}^n$ \(\m ...
- 【Java并发基础】管程简介
前言 在Java 1.5之前,Java语言提供的唯一并发语言就是管程,Java 1.5之后提供的SDK并发包也是以管程为基础的.除了Java之外,C/C++.C#等高级语言也都是支持管程的. 那么什么 ...