【转载】C/走迷宫代码
1 #include<iostream>
2 #include<windows.h>
3 #include"GotoXY.h"
4 #include <conio.h>
5 #include <stdlib.h>
6 #include <time.h>
7 using namespace std;
8 void help();
9 void migong();
10 void m();
11 void help()
12 {
13 char ch2;
14 system("cls");
15 cout<<"操作说明:"<<endl;
16 cout<<endl;
17 cout<<"移动说明:"<<endl;
18 cout<<"w-向上 s-向下 a-向左 d-向右"<<endl;
19 cout<<endl;
20 cout<<"标识说明:"<<endl;
21 cout<<"&- @-玩家 #-墙 $-钥匙 ^-地刺 %-传送门 0-可以被炸开的墙"<<endl;
22 cout<<endl;
23 cout<<"操作说明:"<<endl;
24 cout<<"x-爆破(需要) 移动至物品上方-捡起物品 拥有钥匙后接近传送门附近-传送(按任意键继续)"<<endl;
25 cout<<endl;
26 cout<<"注意事项:"<<endl;
27 cout<<"踩到地刺会s哦,请小心"<<endl;
28 cout<<"按任意键返回"<<endl;
29 ch2=_getch();
30 m();
31 }
32 void migong()
33 {
34 system("cls");
35 char ch;
36 srand(time(NULL));
37 int k;
38 int z=0;
39 int key=0;
40 int zx[100];
41 int zy[100];
42 int gq=0;
43 GotoXY(60,5);
44 cout<<"TNT x 0";
45 while (1)
46 {
47 int map[10][6][10]={
48 {
49 {1,1,1,1,1,1,1,1,1,1},
50 {1,0,3,0,4,0,1,1,0,1},
51 {1,0,0,0,0,1,1,1,2,1},
52 {1,0,0,0,0,1,1,1,0,1},
53 {1,0,0,0,0,0,0,0,0,1},
54 {1,1,1,1,1,1,1,1,1,1}
55 },
56 {
57 {1,1,1,1,1,1,1,1,1,1},
58 {1,0,0,0,0,0,1,0,2,1},
59 {1,0,1,0,1,1,1,0,0,1},
60 {1,0,1,0,0,0,0,0,0,1},
61 {1,3,1,0,0,0,0,4,0,1},
62 {1,1,1,1,1,1,1,1,1,1}
63 },
64 {
65 {1,1,1,1,1,1,1,1,1,1},
66 {1,0,0,0,0,0,0,2,0,1},
67 {1,0,0,3,0,0,0,0,0,1},
68 {1,0,0,0,0,0,0,0,6,1},
69 {1,0,0,5,0,0,0,6,4,1},
70 {1,1,1,1,1,1,1,1,1,1}
71 },
72 {
73 {1,1,1,1,1,1,1,1,1,1},
74 {1,3,1,0,0,0,1,7,4,1},
75 {1,0,1,0,1,0,1,0,0,1},
76 {1,0,1,0,1,2,1,0,7,1},
77 {1,0,0,0,1,0,0,0,7,1},
78 {1,1,1,1,1,1,1,1,1,1}
79 },
80 {
81 {1,1,1,1,1,1,1,1,1,1},
82 {1,1,2,1,1,0,0,0,1,1},
83 {1,1,0,1,1,0,1,0,1,1},
84 {1,0,0,0,0,0,1,0,1,1},
85 {1,3,1,1,1,1,1,0,4,1},
86 {1,1,1,1,1,1,1,1,1,1}
87 },
88 {
89 {1,1,1,1,1,1,1,1,1,1},
90 {1,0,0,0,0,0,0,2,1,1},
91 {1,6,6,6,6,0,1,0,1,1},
92 {1,6,3,5,6,0,1,0,0,1},
93 {1,6,6,6,6,0,0,0,4,1},
94 {1,1,1,1,1,1,1,1,1,1}
95 },
96 {
97 {1,1,1,1,1,1,1,1,1,1},
98 {1,5,0,0,0,0,0,3,0,1},
99 {1,6,6,6,0,0,0,0,0,1},
100 {1,6,2,6,0,0,0,0,0,1},
101 {1,6,6,6,0,0,0,0,4,1},
102 {1,1,1,1,1,1,1,1,1,1}
103 },
104 {
105 {1,1,1,1,1,1,1,1,1,1},
106 {1,2,6,0,0,0,0,6,4,1},
107 {1,7,6,0,0,0,0,6,5,1},
108 {1,6,6,0,6,6,6,6,6,1},
109 {1,0,0,0,6,3,5,0,0,1},
110 {1,1,1,1,1,1,1,1,1,1}
111 },
112 {
113 {1,1,1,1,1,1,1,1,1,1},
114 {1,0,0,0,1,1,0,0,0,1},
115 {1,2,0,0,7,7,0,0,3,1},
116 {1,0,0,0,7,7,0,0,4,1},
117 {1,0,0,0,0,0,0,1,0,1},
118 {1,1,1,1,1,1,1,1,1,1}
119 },
120 {
121 {1,1,1,1,1,1,1,1,1,1},
122 {1,7,7,2,0,0,0,7,7,1},
123 {1,5,7,7,0,0,7,7,5,1},
124 {1,5,7,7,0,0,7,7,5,1},
125 {1,7,3,0,0,0,0,4,7,1},
126 {1,1,1,1,1,1,1,1,1,1}
127 }
128 };
129 k=rand()%10;
130 while (1)
131 {
132 int e=1;
133 int keyx,keyy;
134 int x;
135 int y;
136 int dx;
137 int dy;
138 GotoXY(0,0);
139 for (int i=0;i<6;i++)
140 {
141 for (int j=0;j<10;j++)
142 {
143 if (map[k][i][j]==1)
144 {
145 cout<<"#";
146 }
147 if(map[k][i][j]==0)
148 {
149 cout<<" ";
150 }
151 if(map[k][i][j]==2)
152 {
153 cout<<"$";
154 keyx=i;
155 keyy=j;
156 }
157 if (map[k][i][j]==4)
158 {
159 cout<<"%";
160 dx=i;
161 dy=j;
162 }
163 if (map[k][i][j]==3)
164 {
165 cout<<"@";
166 x=i;
167 y=j;
168 }
169 if (map[k][i][j]==5)
170 {
171 cout<<"&";
172 zx[e]=i;
173 zy[e]=j;
174 e++;
175 }
176 if (map[k][i][j]==6)
177 {
178 cout<<"O";
179 }
180 if (map[k][i][j]==7)
181 {
182 cout<<"^";
183 }
184 }
185 cout<<endl;
186 }
187 if(x==keyx&&y==keyy)
188 {
189 key=1;
190 GotoXY(60,4);
191 cout<<"YOU GET THE KEY!!! ";
192 }
193 else if (x==dx-1&&y==dy||x==dx+1&&y==dy||x==dx&&y==dy+1||x==dx&&y==dy-1)
194 {
195 if (key==1)
196 {
197 GotoXY(60,4);
198 cout<<"YOU WIN!!! <<<按任意键继续>>> ";
199 ch=_getch();
200 key=0;
201 break;
202 }
203 else
204 {
205 GotoXY(60,4);
206 cout<<"NO KEY!!! ";
207 }
208 }
209 for (int i=1;i<=5;i++)
210 {
211 if (x==zx[i]&&y==zy[i])
212 {
213 z+=1;
214 zx[i]=100;
215 zy[i]=100;
216 GotoXY(60,4);
217 cout<<"YOU GET A BAG OF TNT!!! ";
218 GotoXY(66,5);
219 cout<<z;
220 }
221 }
222 GotoXY(60,3);
223 cout<<"第"<<gq<<"层" ;
224 GotoXY(0,6);
225 ch=_getch();
226 switch (ch)
227 {
228 case 'w':
229 if (map[k][x-1][y]==1||map[k][x-1][y]==4||map[k][x-1][y]==6)
230 {
231 break;
232 }
233 else if (map[k][x-1][y]==7)
234 {
235 GotoXY(y,x-1);
236 cout<<"@";
237 GotoXY(y,x);
238 cout<<" ";
239 GotoXY(60,4);
240 cout<<"YOU LOSE!!! ";
241 ch=_getch();
242 system("cls");
243 m();
244 }
245 else
246 {
247 map[k][x-1][y]=3;
248 map[k][x][y]=0;
249 }
250 break;
251 case 's':
252 if (map[k][x+1][y]==1||map[k][x+1][y]==4||map[k][x+1][y]==6)
253 {
254 break;
255 }
256 else if (map[k][x+1][y]==7)
257 {
258 GotoXY(y,x+1);
259 cout<<"@";
260 GotoXY(y,x);
261 cout<<" ";
262 GotoXY(60,4);
263 cout<<"YOU LOSE!!! ";
264 ch=_getch();
265 system("cls");
266 m();
267 }
268 else
269 {
270 map[k][x][y]=0;
271 map[k][x+1][y]=3;
272 }
273 break;
274 case 'a':
275 if (map[k][x][y-1]==1||map[k][x][y-1]==4||map[k][x][y-1]==6)
276 {
277 break;
278 }
279 else if (map[k][x][y-1]==7)
280 {
281 GotoXY(y-1,x);
282 cout<<"@";
283 GotoXY(y,x);
284 cout<<" ";
285 GotoXY(60,4);
286 cout<<"YOU LOSE!!! ";
287 ch=_getch();
288 system("cls");
289 m();
290 }
291 else
292 {
293 map[k][x][y]=0;
294 map[k][x][y-1]=3;
295 }
296 break;
297 case 'd':
298 if (map[k][x][y+1]==1||map[k][x][y+1]==4||map[k][x][y+1]==6)
299 {
300 break;
301 }
302 else if (map[k][x][y+1]==7)
303 {
304 GotoXY(y+1,x);
305 cout<<"@";
306 GotoXY(y,x);
307 cout<<" ";
308 GotoXY(60,4);
309 cout<<"YOU LOSE!!! ";
310 ch=_getch();
311 system("cls");
312 m();
313 }
314 else
315 {
316 map[k][x][y]=0;
317 map[k][x][y+1]=3;
318 }
319 break;
320 case 'x':
321 if (z>0)
322 {
323 z--;
324 GotoXY(66,5);
325 cout<<z<<" ";
326 for (int m=x-1;m<=x+1;m++)
327 {
328 for (int d=y-1;d<=y+1;d++)
329 {
330 if (map[k][m][d]==6)
331 {
332 map[k][m][d]=0;
333 }
334 }
335 }
336 }
337 else
338 {
339 GotoXY(60,4);
340 cout<<"YOU DON'T HAVE ANY TNT!!! ";
341 }
342 break;
343 }
344 }
345 GotoXY(0,7);
346 gq++;
347 key=0;
348 }
349 }
350 void m()
351 {
352 system("cls");
353 char ch1;
354 system("title 迷宫-作者S_JH330206");
355 cout<<" 迷宫游戏"<<endl;
356 cout<<"----------------------------------------------------------------"<<endl;
357 cout<<endl;
358 cout<<" [h]帮助"<<endl;
359 cout<<" [m]游戏"<<endl;
360 cout<<endl;
361 cout<<"----------------------------------------------------------------"<<endl;
362 ch1=_getch();
363 if (ch1=='m')
364 {
365 migong();
366 }
367 if (ch1=='h')
368 {
369 help();
370 }
371 else
372 {
373 m();
374 }
375 }
376 int main()
377 {
378 m();
379 return 0;
380 }
这个是脚本的自定义头文件:
1 #include<iostream>
2 #include<windows.h>
3 void GotoXY(int x, int y) // 移动
4 {
5 HANDLE hout; //屏幕尺寸 变量
6 COORD coord={x,y}; //光标坐标 变量 光标x标 光标y标
7 hout=GetStdHandle(STD_OUTPUT_HANDLE); //获得屏幕尺寸
8 SetConsoleCursorPosition(hout,coord); //移动光标
9 }
【转载】C/走迷宫代码的更多相关文章
- C语言动态走迷宫
曾经用C语言做过的动态走迷宫程序,先分享代码如下: 代码如下: //头文件 #include<stdio.h> #include<windows.h>//Sleep(500)函 ...
- 洛谷P1238 走迷宫
洛谷1238 走迷宫 题目描述 有一个m*n格的迷宫(表示有m行.n列),其中有可走的也有不可走的,如果用1表示可以走,0表示不可以走,文件读入这m*n个数据和起始点.结束点(起始点和结束点都是用两个 ...
- NYOJ306 走迷宫(dfs+二分搜索)
题目描写叙述 http://acm.nyist.net/JudgeOnline/problem.php?pid=306 Dr.Kong设计的机器人卡多非常爱玩.它经常偷偷跑出实验室,在某个游乐场玩之不 ...
- P1238 走迷宫
原题链接 https://www.luogu.org/problemnew/show/P1238 为了巩固一下刚学习的广搜,练一下迷宫类型的题 不过这道题我用的深搜..... 看问题,我们就知道这道题 ...
- 洛谷P1238 走迷宫题解
题目描述 有一个m*n格的迷宫(表示有m行.n列),其中有可走的也有不可走的,如果用1表示可以走,0表示不可以走,文件读入这m*n个数据和起始点.结束点(起始点和结束点都是用两个数据来描述的,分别表示 ...
- 一本通之 一堆迷宫 (Dungeon Master&走出迷宫&走迷宫)
一本通在线崩溃....... . 有图有真相 这是个三维迷宫,其实和二位迷宫差不多,只是方向多加了2个. 但这个题的输入十分恶心,一度被坑的用cin.ignore(),但还是不过... 它的正确输入方 ...
- HDU 2102 A计划(BFS/DFS走迷宫)
A计划 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...
- golang广度优先算法-走迷宫
广度优先遍历,走迷宫思路: 1.创建二维数组,0表示是路,1表示是墙:创建队列Q,存储可遍历的点,Q的第一个元素为起始点 2.从队列中取一个点,开始,按上.左.下.右的顺序遍历周围的点next,nex ...
- 用Q-learning算法实现自动走迷宫机器人
项目描述: 在该项目中,你将使用强化学习算法,实现一个自动走迷宫机器人. 如上图所示,智能机器人显示在右上角.在我们的迷宫中,有陷阱(红色炸弹)及终点(蓝色的目标点)两种情景.机器人要尽量避开陷阱.尽 ...
随机推荐
- Netty源码分析之ByteBuf(一)—ByteBuf中API及类型概述
ByteBuf是Netty中主要的数据容器与操作工具,也是Netty内存管理优化的具体实现,本章我们先从整体上对ByteBuf进行一个概述: AbstractByteBuf是整个ByteBuf的框架类 ...
- 前端修仙之路---一、如何用gulp搭建一套web前端开发框架
引言 相信从事web前端开发的朋友都知道,现在流行的Vue.AngularJS等框架中,它们都有独立的脚手架来创建项目,比如Vue有vue-cli,Angular有angula-cli.脚手架可以一键 ...
- Unity坑之 加了Rigidbody后主角反而朝天上飞?
今儿在做项目的时候,给主角加上一个Rigidbody组件,设置如下图: 然后问题来了,我本来是想让主角通过重力控制,掉到地上,但是加上之后,主角反而朝着天上飞! 这TM什么鬼? 经过多番探查,发现是A ...
- 面试:为了进阿里,又把并发CAS(Compare and Swap)实现重新精读一遍
该系列文章已收录在公众号[Ccww技术博客],原创技术文章第一时间推出 前言 在面试中,并发线程安全提问必然是不会缺少的,那基础的CAS原理也必须了解,这样在面试中才能加分,那来看看面试可能会问那些问 ...
- SpringBoot—整合log4j2入门和log4j2.xml配置详解
关注微信公众号:CodingTechWork,一起学习进步. 引言 对于一个线上程序或者服务而言,重要的是要有日志输出,这样才能方便运维.而日志的输出需要有一定的规划,如日志命名.日志大小,日志分 ...
- Linux:mysql编译安装
mysql安装包有源码包和二进制包.源码包安装时需要编译.二进制包安装时不需要编译. 二进制格式的包名字很长,都带有版本号.适应平台.适应的硬件类型等,而源码格式仅仅就是一个版本号的tar包. 源代码 ...
- 本机ping不通虚拟机,但虚拟机可以ping通本机时怎么解决
在各自网络都连接的情况下,本机ping不通虚拟机,但虚拟机可以ping通本机时解决方案: 1.linux虚拟机中连接方式选择NAT模式 2.本地启动VMnet8,然后选择VMnet8的属性,手动输入和 ...
- 掌控安全sql注入靶场pass-05
1.判断注入点 1 and 1=1 1 and 1=2 考虑存在布尔盲注 布尔盲注解释 当不能像前面那样直接在网页中显示我们要的数据时就需要用到盲注,来得到数据库之类的名字.基于布尔的盲注就是通过判断 ...
- 故事:坐在我隔壁的小王问我什么是HyperLogLog
1 最近坐我隔壁的小王同志,心情真是糟透了.不但工作不顺心,被老板狠狠的批了一顿,连女朋友也跟别人跑了(Y 的让你天天在我面前秀). 真是不可谓不惨,我都快要同情他了. 看着他萎靡又迷离的眼神,我实在 ...
- Win10安装Tensorflow-gpu遇到Could not install packages due to an EnvironmentError: [WinError 5] 拒绝访问
最近因为上课需要安装Anaconda和Tensorflow,安装Anaconda后再使用 Tensorflow官网提供的pip安装Tensorflow-GPU方法会出现如下错误: 解决方法:在安装命令 ...