




已阅读5页,还剩1页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
/* 云风的求解最短路径代码 (Cloud Wus Pathfinding code) * 1999 年 1月 8 日 (1999, Jan 8) * 这段代码没有进行任何优化(包括算法上的), 但不意味我不知道该怎样优化它, * 它是为教学目的而做,旨在用易于理解和简洁的代码描述出 A* 算法在求最段路 * 径中的运用. 由于很久没有摸算法书, 本程序不能保证是纯正的 A* 算法 ;-) * 你可以在理解了这段程序的基础上,按自己的理解写出类似的代码. 但是简单的 * 复制它到你的程序中是不允许的,如果你真要这样干,请在直接使用它的软件的 * 文档中,写上我的名字 ;-) * 有任何的问题,或建议请 E-mail 到 * 欢迎参观我的主页 /cloudwu (云风工作室) * (你可以在上面找到一些有关这个问题的讨论,和有关游戏设计的其它大量资料) * * 本程序附带有一个数据文件 map.dat, 保存有地图的数据 */ #define NDEBUG#include #include #include #include #define MAPMAXSIZE 100 /地图面积最大为 100x100#define MAXINT 8192 /定义一个最大整数, 地图上任意两点距离不会超过它#define STACKSIZE 65536 /保存搜索节点的堆栈大小#define tile_num(x,y) (y)*map_w+(x) /将 x,y 坐标转换为地图上块的编号#define tile_x(n) (n)%map_w) /由块编号得出 x,y 坐标#define tile_y(n) (n)/map_w)/ 树结构, 比较特殊, 是从叶节点向根节点反向链接typedef struct node *TREE;struct node int h; int tile;TREE father; ;typedef struct node2 *LINK;struct node2 TREE node; int f; LINK next; ;LINK queue; / 保存没有处理的行走方法的节点TREE stackSTACKSIZE; / 保存已经处理过的节点 (搜索完后释放)int stacktop;unsigned char mapMAPMAXSIZEMAPMAXSIZE; /地图数据int dis_mapMAPMAXSIZEMAPMAXSIZE; /保存搜索路径时,中间目标地最优解int map_w,map_h; /地图宽和高int start_x,start_y,end_x,end_y; /地点,终点坐标/ 初始化队列void init_queue() queue=(LINK)malloc(sizeof(*queue); queue-node=NULL; queue-f=-1; queue-next=(LINK)malloc(sizeof(*queue); queue-next-f=MAXINT; queue-next-node=NULL; queue-next-next=NULL;/ 待处理节点入队列, 依靠对目的地估价距离插入排序void enter_queue(TREE node,int f) LINK p=queue,father,q; while(fp-f) father=p; p=p-next; assert(p); q=(LINK)malloc(sizeof(*q); assert(queue); q-f=f,q-node=node,q-next=p; father-next=q;/ 将离目的地估计最近的方案出队列TREE get_from_queue() TREE bestchoice=queue-next-node; LINK next=queue-next-next; free(queue-next); queue-next=next; stackstacktop+=bestchoice; assert(stacktopSTACKSIZE); return bestchoice;/ 释放栈顶节点void pop_stack() free(stack-stacktop);/ 释放申请过的所有节点void freetree() int i; LINK p; for (i=0;inode); queue=queue-next; free(p); / 估价函数,估价 x,y 到目的地的距离,估计值必须保证比实际值小int judge(int x,int y) int distance; distance=abs(end_x-x)+abs(end_y-y); return distance;/ 尝试下一步移动到 x,y 可行否int trytile(int x,int y,TREE father) TREE p=father; int h; if (mapyx!= ) return 1; / 如果 (x,y) 处是障碍,失败 while (p) if (x=tile_x(p-tile) & y=tile_y(p-tile) return 1; /如果 (x,y) 曾经经过,失败 p=p-father; h=father-h+1; if (h=dis_mapyx) return 1; / 如果曾经有更好的方案移动到 (x,y) 失败 dis_mapyx=h; / 记录这次到 (x,y) 的距离为历史最佳距离/ 将这步方案记入待处理队列 p=(TREE)malloc(sizeof(*p); p-father=father; p-h=father-h+1; p-tile=tile_num(x,y); enter_queue(p,p-h+judge(x,y); return 0;/ 路径寻找主函数void findpath(int *path) TREE root; int i,j; stacktop=0; for (i=0;imap_h;i+) for (j=0;jtile=tile_num(start_x,start_y); root-h=0; root-father=NULL; enter_queue(root,judge(start_x,start_y); for (;) int x,y,child; TREE p; root=get_from_queue(); if (root=NULL) *path=-1; return; x=tile_x(root-tile); y=tile_y(root-tile); if (x=end_x & y=end_y) break; / 达到目的地成功返回 child=trytile(x,y-1,root); /尝试向上移动 child&=trytile(x,y+1,root); /尝试向下移动 child&=trytile(x-1,y,root); /尝试向左移动 child&=trytile(x+1,y,root); /尝试向右移动 if (child!=0) pop_stack(); / 如果四个方向均不能移动,释放这个死节点 / 回溯树,将求出的最佳路径保存在 path 中 for (i=0;root;i+) pathi=root-tile; root=root-father; pathi=-1; freetree();void printpath(int *path) int i; for (i=0;pathi=0;i+) gotoxy(tile_x(pathi)+1,tile_y(pathi)+1); cprintf(xfe); int readmap() FILE *f; int i,j; f=fopen(map.dat,r); assert(f); fscanf(f,%d,%dn,&map_w,&map_h); for (i=0;imap_h;i+)fgets(&mapi0,map_w+1,f); fclose(f); start_x=-1,end_x=-1; for (i=0;imap_h;i+) for (j=0;j=0 & end_x=0); return 0;void showmap() int i,j; clrscr(); for (i=0;imap_h;i+) gotoxy(1,i+1); for (j=0;jmap_w;j+) if (mapij!= ) cprintf(xdb); else cprintf(
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 停车场智能收费系统招标
- 客户需求调查表-个性化需求分析
- 统编三年级下册《赵州桥》公开课课件(有配套教案)
- 跨境电商 的物流
- 建筑施工现场安全监督指南
- 外科总论练习卷附答案
- 医疗机构运营与管理作业指导书
- 办公区装修活动策划方案
- 关于新产品开发策略的讨论结果反馈
- 企业节能减排技术创新与应用方案
- GB/T 5778-1986膨胀合金气密性试验方法
- GB/T 5455-2014纺织品燃烧性能垂直方向损毁长度、阴燃和续燃时间的测定
- GB/T 5117-2012非合金钢及细晶粒钢焊条
- GB/T 3782-2006乙炔炭黑
- 大国医魂:800年滋阴派与600年大德昌课件
- 真核生物的转录
- 《电商企业财务风险管理-以苏宁易购为例开题报告》
- 公司组织架构图(可编辑模版)
- 中小学综合实践活动课程指导纲要
- 清淤工程施工记录表
- 黄河上游历史大洪水市公开课金奖市赛课一等奖课件
评论
0/150
提交评论