#include <stdio.h>

#define ROW 6

#define COL 6

// 封装打印地图的函数

void printMap(char map[][COL]) {

for (int i =
0; i < ROW; i++) {

for (int j =
0; j < COL; j++) {

printf("%c", map[i][j]);

}

printf("\n");

}

}

int isSuccess(int x,
int y) {

return x ==
0 || x == ROW -
1 || y == 0 || y ==
COL - 1;

}

char inputChar() {

char input;

while (1) {

printf("> ");

input = getchar();

while (getchar() !=
'\n') ;

if (input ==
'w' || input == 's' || input ==
'a' || input == 'd') {

break;

}

}

return input;

}

int main(int argc,
const char * argv[]) {

char map[ROW][COL]={

{'#','#','#','#','#','#'},

{'#','O','#','#','
',' '},

{'#',' ','#','#','
','#'},

{'#',' ',' ','#','
','#'},

{'#','#',' ',' ','
','#'},

{'#','#','#','#','#','#'}

};

char input;

// 表示人的位置

int x =
1;

int y =
1;

while (1) {

// 打印

printMap(map);

// 胜利的代码

if (isSuccess(x, y))
break;

// 提示用户的输入

printf("请输入 w(上) s(下)
a(左) d(右)\n");

// 输入数据,
判断正确

input = inputChar();

// 更新地图`

switch (input) {

case
'W':

case
'w':

//
判断下一个位置是否可以走, 如果可以走就交换地图中的数据

//
如果不能走就不变

//
即 判断 (x - 1, y)
是不是空格, 如果是空格就可以走

if (map[x -
1][y] == ' ') {

//
交换

int temp = map[x -
1][y];

map[x - 1][y] = map[x][y];

map[x][y] = temp;

//
交换后更新 x y

x--;

}

break;

case
's':

if (map[x +
1][y] == ' ') {

//
交换

int temp = map[x +
1][y];

map[x + 1][y] = map[x][y];

map[x][y] = temp;

//
交换后更新 x y

x++;

}

break;

case
'a':

if (map[x][y -
1] == ' ') {

//
交换

int temp = map[x][y -
1];

map[x][y - 1] = map[x][y];

map[x][y] = temp;

//
交换后更新 x y

y--;

}

break;

case
'd':

if (map[x][y +
1] == ' ') {

//
交换

int temp = map[x][y +
1];

map[x][y + 1] = map[x][y];

map[x][y] = temp;

//
交换后更新 x y

y++;

}

break;

}

// 清屏

system("clear");

}

printf("恭喜你重获自由...\n");

return
0;

}

版权声明:本文为博主原创文章,未经博主允许不得转载。

利用c语言做简单的迷宫小游戏的更多相关文章

  1. Java用户输入数值,做简单的猜数字游戏,导入基础的工具包util

    Java用户输入数值,做简单的猜数字游戏,导入基础的工具包util,导入包的方法为,import java.util.*: 完整的实例代码: /* 导入基础工具包 */ import java.uti ...

  2. 我用数据结构花了一夜给女朋友写了个h5走迷宫小游戏

    目录 起因 分析 画线(棋盘) 画迷宫 方块移动 结语 @(文章目录) 先看效果图(在线电脑尝试地址http://biggsai.com/maze.html): 起因 又到深夜了,我按照以往在公众号写 ...

  3. c++迷宫小游戏

    c++迷宫小游戏 一.总结 一句话总结: 显示:根据map数组输出图像 走动:修改map数组的值,每走一步重新刷新一下图像就好 1.如果走函数用z(),出现输入s会向下走多步的情况,原因是什么? 向下 ...

  4. js实现简单的俄罗斯方块小游戏

    js实现简单的俄罗斯方块小游戏 开始 1. 创建一个宽为 200px,高为 360px 的背景容器 <!DOCTYPE html> <html lang="en" ...

  5. 用Java语言编写的迷宫小游戏软件

    可查看本项目的github 源码链接,撒娇打滚求 star 哦~~ღ( ´・ᴗ・ ` )比心 本仓库代码是经过 eclipse 编译运行过的,一般情况下将本仓库代码下载下来之后,使用 eclipse ...

  6. 每个人都可以用C语言写的推箱子小游戏!今天你就可以写出属于自己项目~

    C语言,作为大多数人的第一门编程语言,重要性不言而喻,很多编程习惯,逻辑方式在此时就已经形成了.这个是我在大一学习 C语言 后写的推箱子小游戏,自己的逻辑能力得到了提升,在这里同大家分享这个推箱子小游 ...

  7. C语言-纸牌计算24点小游戏

    C语言实现纸牌计算24点小游戏 利用系统时间设定随机种子生成4个随机数,并对4个数字之间的运算次序以及运算符号进行枚举,从而计算判断是否能得出24,以达到程序目的.程序主要功能已完成,目前还有部分细节 ...

  8. 用WPF做了几个小游戏

    最近看书看累了,参考别人的代码(其实差不多就是把代码重新打了一遍o(╯□╰)o),用wpf做了个<2048>小游戏,顺便在<Git教程>学习下git,也顺便把在<写让别人 ...

  9. 使用 App Inventor 2 开发简单的安卓小游戏

    App Inventor2 是一个简单的在线开发安卓应用程序的工具,通过此工具,我们可以很轻松地开发安卓应用. 这里介绍的是笔者自己写的一个小游戏,游戏中玩家通过左右倾斜手机控制“水库”的左右移动,收 ...

随机推荐

  1. HDU-- Buy Tickets

    告知每次要插到第 i 个位置上,问最后它们的顺序是什么. 这一题,不是考线段树,是考如何想出用线段树...思维很巧妙,倒过来做的话就能确定此人所在的位置....   Buy Tickets Time ...

  2. python多进程的理解 multiprocessing Process join run

    最近看了下多进程. 一种接近底层的实现方法是使用 os.fork()方法,fork出子进程.但是这样做事有局限性的.比如windows的os模块里面没有 fork() 方法. windows:.lin ...

  3. time.h

    目录 1简介 2代码示例 3从系统时钟获取时间方式 4time函数介绍 函数名称: localtime 函数名称: asctime 函数名称: ctime 函数名称: difftime 函数名称: g ...

  4. 解析XML文件示例

    项目中要解析Xml文件,于是在工程里找了下前人写例子. 1,SAX(基于事件,效率高,使用声明加载什么). public class MVCConfig { private static MVCCon ...

  5. 在Ubuntu 中安装eclipse, eclipse 文件已经下载好!

    If you've downloaded Eclipse from their official website, follow these steps for the installation. E ...

  6. HTML5 Canvas核心技术—图形、动画与游戏开发.pdf3

    路径与子路径 在某一时刻,canvas之中只能有一条路径存在,Canvas规范称之为“当前路径”(current path),这条路径却可以包含很多子路径(subpath),子路径是由两个或者更多点组 ...

  7. replace empty char with new string,unsafe method和native implementation的性能比较

    1: class Program 2: { 3: static void Main(string[] args) 4: { 5: string s = File.ReadAllText(@" ...

  8. spider爬站极度损耗站点流量

    或许部分站长遇到过这样的情况,Baiduspider对一个网站的抓取频率要远高于新内容产出速度,造成了N多的流量被蜘蛛占用. 这样的情况一般是针对小站,因为大站访问量很大,蜘蛛对服务器的频繁访问不会有 ...

  9. hdoj 1083 Courses【匈牙利算法】

    Courses Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total S ...

  10. 单点登录SSO的实现原理

    单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户的一次登录能得到其他所有系统的信任.单点登录在大型网站里使用得 ...