利用c语言做简单的迷宫小游戏
#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语言做简单的迷宫小游戏的更多相关文章
- Java用户输入数值,做简单的猜数字游戏,导入基础的工具包util
Java用户输入数值,做简单的猜数字游戏,导入基础的工具包util,导入包的方法为,import java.util.*: 完整的实例代码: /* 导入基础工具包 */ import java.uti ...
- 我用数据结构花了一夜给女朋友写了个h5走迷宫小游戏
目录 起因 分析 画线(棋盘) 画迷宫 方块移动 结语 @(文章目录) 先看效果图(在线电脑尝试地址http://biggsai.com/maze.html): 起因 又到深夜了,我按照以往在公众号写 ...
- c++迷宫小游戏
c++迷宫小游戏 一.总结 一句话总结: 显示:根据map数组输出图像 走动:修改map数组的值,每走一步重新刷新一下图像就好 1.如果走函数用z(),出现输入s会向下走多步的情况,原因是什么? 向下 ...
- js实现简单的俄罗斯方块小游戏
js实现简单的俄罗斯方块小游戏 开始 1. 创建一个宽为 200px,高为 360px 的背景容器 <!DOCTYPE html> <html lang="en" ...
- 用Java语言编写的迷宫小游戏软件
可查看本项目的github 源码链接,撒娇打滚求 star 哦~~ღ( ´・ᴗ・ ` )比心 本仓库代码是经过 eclipse 编译运行过的,一般情况下将本仓库代码下载下来之后,使用 eclipse ...
- 每个人都可以用C语言写的推箱子小游戏!今天你就可以写出属于自己项目~
C语言,作为大多数人的第一门编程语言,重要性不言而喻,很多编程习惯,逻辑方式在此时就已经形成了.这个是我在大一学习 C语言 后写的推箱子小游戏,自己的逻辑能力得到了提升,在这里同大家分享这个推箱子小游 ...
- C语言-纸牌计算24点小游戏
C语言实现纸牌计算24点小游戏 利用系统时间设定随机种子生成4个随机数,并对4个数字之间的运算次序以及运算符号进行枚举,从而计算判断是否能得出24,以达到程序目的.程序主要功能已完成,目前还有部分细节 ...
- 用WPF做了几个小游戏
最近看书看累了,参考别人的代码(其实差不多就是把代码重新打了一遍o(╯□╰)o),用wpf做了个<2048>小游戏,顺便在<Git教程>学习下git,也顺便把在<写让别人 ...
- 使用 App Inventor 2 开发简单的安卓小游戏
App Inventor2 是一个简单的在线开发安卓应用程序的工具,通过此工具,我们可以很轻松地开发安卓应用. 这里介绍的是笔者自己写的一个小游戏,游戏中玩家通过左右倾斜手机控制“水库”的左右移动,收 ...
随机推荐
- 论SOA架构的几种主要开发方式【转】
面向服务架构soa以其独特的优势越来越受到企业的重视,它可以根据需求通过网络对松散耦合的粗粒度应用组件进行分布式部署.组合和使用.服务层是SOA的基础,可以直接被应用调用,从而有效控制系 ...
- Bzoj 2141: 排队 分块,逆序对,树状数组
2141: 排队 Time Limit: 4 Sec Memory Limit: 259 MBSubmit: 1310 Solved: 517[Submit][Status][Discuss] D ...
- Staitic(静态) 相关知识点介绍
一.什么是 Static? Static 关键字:表明一个成员变量或者是成员方法可以在没有所属的类的实例的情况下直接被访问 当成员被静态修饰后,就多了一个调用方式,除了可被对象调用外还可以直接被类名调 ...
- TimeSpan XML序列化
/// <summary> /// 刷新时间 默认为1秒 /// </summary> /// <value>The refresh time.</value ...
- NIO机制总结
Selector selector = Selector.open(); 普通的IO流的读取,写入都是一个字节一个字节或一个字符一个字符的循环进行,在这个过程中,程序是阻塞的,inputStream虽 ...
- CONTROLS: <> TYPE TABLEVIEW USING SCREEN<>.在 ABAP/4 中声明表格 控制
在 ABAP/4 中声明表格 控制 在屏幕中使 用表格控制 时,必须在 ABAP/4 程序中同时 声明表格控 制结构和表 格控制字段 . 例如: TABLES: SFLIGHT. CONTROLS ...
- 遮罩层的实现(纯js兼容版)
这个代码是我以前测试时候的代码了,主要用到的知识点是opacity和filer分别实现 “标准浏览器”和IE浏览器下的半透明,使用js的document.body.offsetwidth 和scree ...
- 在mysql中修改表名的sql语句
在使用mysql时,经常遇到表名不符合规范或标准,但是表里已经有大量的数据了,如何保留数据,只更改表名呢?可以通过建一个相同的表结构的表,把原来的数据导入到新表中,但是这样视乎很麻烦.能否简单使用一个 ...
- jbpm6 开发环境搭建
一.软件下载 1. eclipse 下载地址:http://www.eclipse.org/downloads/ 2.jbpm6.2 Installer 下载地址: ht ...
- gist c code
http://lear.inrialpes.fr/software Fisher kernel: http://vision.caltech.edu/~sbranson/code/index.html ...