已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
C语言编写的迷宫小游戏 源代码#include #include #include #include #include #define N 20/*迷宫的大小,可改变*/int oldmapNN;/*递归用的数组,用全局变量节约时间*/int yes=0;/*yes是判断是否找到路的标志,1找到,0没找到*/int way1002,wayn=0;/*way数组是显示路线用的,wayn是统计走了几个格子*/void Init(void);/*图形初始化*/void Close(void);/*图形关闭*/void DrawPeople(int *x,int *y,int n);/*画人工探索物图*/void PeopleFind(int (*x)N);/*人工探索*/void WayCopy(int (*x)N,int (*y)N);/*为了8个方向的递归,把旧迷宫图拷贝给新数组*/int FindWay(int (*x)N,int i,int j);/*自动探索函数*/void MapRand(int (*x)N);/*随机生成迷宫函数*/void PrMap(int (*x)N);/*输出迷宫图函数*/void Result(void);/*输出结果处理*/void Find(void);/*成功处理*/void NotFind(void);/*失败处理*/void main(void)/*主函数*/ int mapNN; /*迷宫数组*/ char ch; clrscr(); printf(n Please select hand(1) else auton);/*选择探索方式*/ scanf(%c,&ch); Init(); /*初始化*/ MapRand(map);/*生成迷宫*/ PrMap(map);/*显示迷宫图*/ if(ch=1) PeopleFind(map);/*人工探索*/ else FindWay(map,1,1);/*系统自动从下标1,1的地方开始探索*/ Result();/*输出结果*/ Close();void Init(void)/*图形初始化*/ int gd=DETECT,gm; initgraph(&gd,&gm,c:tc);void DrawPeople(int *x,int *y,int n)/*画人工控制图*/*如果将以下两句注释掉,则显示人工走过的路径,*/ setfillstyle(SOLID_FILL,WHITE); /*设置白色实体填充样式*/ bar(100+(*y)*15-6,50+(*x)*15-6,100+(*y)*15+6,50+(*x)*15+6);/*恢复原通路*/ switch(n)/*判断x,y的变化,8个方向的变化*/ case 1: (*x)-;break; /*上*/ case 2: (*x)-;(*y)+;break ;/*右上*/ case 3: (*y)+;break; /*右*/ case 4: (*x)+;(*y)+;break; /*右下*/ case 5: (*x)+;break; /*下*/ case 6: (*x)+;(*y)-;break; /*左下*/ case 7: (*y)-;break; /*左*/ case 8: (*x)-;(*y)-;break; /*左上*/ setfillstyle(SOLID_FILL,RED);/*新位置显示探索物*/ bar(100+(*y)*15-6,50+(*x)*15-6,100+(*y)*15+6,50+(*x)*15+6);void PeopleFind(int (*map)N)/*人工手动查找*/ int x,y; char c=0;/*接收按键的变量*/ x=y=1;/*人工查找的初始位置*/ setcolor(11); line(500,200,550,200); outtextxy(570,197,d); line(500,200,450,200); outtextxy(430,197,a); line(500,200,500,150); outtextxy(497,130,w); line(500,200,500,250); outtextxy(497,270,x); line(500,200,450,150); outtextxy(445,130,q); line(500,200,550,150); outtextxy(550,130,e); line(500,200,450,250); outtextxy(445,270,z); line(500,200,550,250); outtextxy(550,270,c);/*以上是画8个方向的控制介绍*/ setcolor(YELLOW); outtextxy(420,290,Press Enter to end);/*压回车键结束*/ setfillstyle(SOLID_FILL,RED); bar(100+y*15-6,50+x*15-6,100+y*15+6,50+x*15+6);/*入口位置显示*/ while(c!=13)/*如果按下的不是回车键*/ c=getch();/*接收字符后开始各个方向的探索*/ if(c=w&mapx-1y!=1) DrawPeople(&x,&y,1);/*上*/ else if(c=e&mapx-1y+1!=1) DrawPeople(&x,&y,2);/*右上*/ else if(c=d&mapxy+1!=1) DrawPeople(&x,&y,3);/*右*/ else if(c=c&mapx+1y+1!=1) DrawPeople(&x,&y,4);/*右下*/ else if(c=x&mapx+1y!=1) DrawPeople(&x,&y,5);/*下*/ else if(c=z&mapx+1y-1!=1)DrawPeople(&x,&y,6); /*左下*/ elseif(c=a&mapxy-1!=1) DrawPeople(&x,&y,7); /*左*/else if(c=q&mapx-1y-1!=1) DrawPeople(&x,&y,8); /*左上*/ setfillstyle(SOLID_FILL,WHITE); /*消去红色探索物,恢复原迷宫图*/ bar(100+y*15-6,50+x*15-6,100+y*15+6,50+x*15+6); if(x=N-2&y=N-2)/*人工控制找成功的话*/ yes=1; /*如果成功标志为1*/void WayCopy(int (*oldmap)N,int (*map)N)/*拷贝迷宫数组 */ int i,j; for(i=0;iN;i+) for(j=0;jN;j+) oldmapij=mapij;int FindWay(int (*map)N,int i,int j)/*递归找路*/ if(i=N-2&j=N-2)/*走到出口*/ yes=1;/*标志为1,表示成功*/ return; mapij=1;/*走过的地方变为1*/ WayCopy(oldmap,map); /*拷贝迷宫图*/ if(oldmapi+1j+1=0&!yes)/*判断右下方是否可走*/ FindWay(oldmap,i+1,j+1); if(yes)/*如果到达出口了,再把值赋给显示路线的way数组,也正是这个原因,所以具体路线是从最后开始保存*/ waywayn0=i; waywayn+1=j; return; WayCopy(oldmap,map); if(oldmapi+1j=0&!yes)/*判断下方是否可以走,如果标志yes已经是1也不用找下去了*/ FindWay(oldmap,i+1,j); if(yes) waywayn0=i; waywayn+1=j; return; WayCopy(oldmap,map); if(oldmapij+1=0&!yes)/*判断右方是否可以走*/ FindWay(oldmap,i,j+1); if(yes) waywayn0=i; waywayn+1=j; return; WayCopy(oldmap,map); if(oldmapi-1j=0&!yes)/*判断上方是否可以走*/ FindWay(oldmap,i-1,j); if(yes) waywayn0=i; waywayn+1=j; return; WayCopy(oldmap,map); if(oldmapi-1j+1=0&!yes)/*判断右上方是否可以走*/ FindWay(oldmap,i-1,j+1); if(yes) waywayn0=i; waywayn+1=j; return; WayCopy(oldmap,map); if(oldmapi+1j-1=0&!yes)/*判断左下方是否可以走*/ FindWay(oldmap,i+1,j-1); if(yes) waywayn0=i; waywayn+1=j; return; WayCopy(oldmap,map); if(oldmapij-1=0&!yes)/*判断左方是否可以走*/ FindWay(oldmap,i,j-1); if(yes) waywayn0=i; waywayn+1=j; return; WayCopy(oldmap,map); if(oldmapi-1j-1=0&!yes)/*判断左上方是否可以走*/ FindWay(oldmap,i-1,j-1); if(yes) waywayn0=i; waywayn+1=j; return; return;void MapRand(int (*map)N)/*开始的随机迷宫图*/ int i,j; cleardevice();/*清屏*/ randomize(); /*随机数发生器*/ for(i=0;iN;i+) for(j=0;jN;j+) if(i=0|i=N-1|j=0|j=N-1)/*最外面一圈为墙壁*/ mapij=1; else if(i=1&j=1|i=N-2&j=N-2)/*出发点与终点表示为可走的*/ mapij=0; else mapij=random(2);/*其它的随机生成0或1*/ void PrMap(int (*map)N)/*输出迷宫图*/ int i,j; for(i=0;iN;i+) for(j=0;j=0;i-) bar(100+wayi1*15-6,50+wayi0*15-6,100+ wayi1*15+6,50+wayi0*15+6); sleep(1);/*控制显示时间*/ bar(100+(N-2)*15-6,50+(N-2)*15-6,100+(N-2)*15+6,50+(N-2)*15+6); /*在目标点标红色*/ setcolor(GREEN); settextstyle(0,0,2);/*设置字体大小*/ outtextxy(130,400,Fi
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年经济师初级工商管理模拟题总结及答案
- 企业人力资源管理师级人力资源管理师试卷含答案
- 数字化赋能乡镇发展:经济服务与管理一体化系统的构建与实践
- 数字化浪潮下中国手机广告传播形态的多维度剖析与展望
- 数字化浪潮下RRZL公司市场营销战略转型与创新研究
- 园林古建筑基础设施建设技术方案
- 医疗救援建设进度管理方案
- 土方开挖施工技术方案
- 施工现场电气设备管理办法
- 工业尾气二氧化碳综合处理利用项目商业计划书
- 2023年安徽省中学生生物学竞赛预赛试卷-完整版
- 基坑开挖风险评估报告
- 水生动物增殖放流技术规范
- 纪委办公室室内改造项目可行性研究报告
- GB/T 22900-2022科学技术研究项目评价通则
- GB/T 17880.6-1999铆螺母技术条件
- SB/T 11094-2014中药材仓储管理规范
- GB/T 23339-2018内燃机曲轴技术条件
- 污废水处理培训教材课件
- 实验12土壤微生物的分离及纯化课件
- 2022年4月自考00402学前教育史试题及答案
评论
0/150
提交评论