5 6 .XX.1. ..X.2. 2...X. ...XX. XXXXX. 5 6 .XX.1. ..X.2. 2...X. ...XX. XXXXX1 5 6 .XX... ..XX1. 2...X. ...XX. XXXXX.
It takes 13 seconds to reach the target position, let me show you the way. 1s:(0,0)->(1,0) 2s:(1,0)->(1,1) 3s:(1,1)->(2,1) 4s:(2,1)->(2,2) 5s:(2,2)->(2,3) 6s:(2,3)->(1,3) 7s:(1,3)->(1,4) 8s:FIGHT AT (1,4) 9s:FIGHT AT (1,4) 10s:(1,4)->(1,5) 11s:(1,5)->(2,5) 12s:(2,5)->(3,5) 13s:(3,5)->(4,5) FINISH It takes 14 seconds to reach the target position, let me show you the way. 1s:(0,0)->(1,0) 2s:(1,0)->(1,1) 3s:(1,1)->(2,1) 4s:(2,1)->(2,2) 5s:(2,2)->(2,3) 6s:(2,3)->(1,3) 7s:(1,3)->(1,4) 8s:FIGHT AT (1,4) 9s:FIGHT AT (1,4) 10s:(1,4)->(1,5) 11s:(1,5)->(2,5) 12s:(2,5)->(3,5) 13s:(3,5)->(4,5) 14s:FIGHT AT (4,5) FINISH God please help our poor hero. FINISH 经典的广搜题,用到了优先队列和打表存储,要注意优先队列的弹出队首元素是 .top(), 再注意一下开的数据大小问题,慢慢来,就可以AC// 数据空间都要开大一点哟,刚开始我开的30,30结果一直WA #include <stdio.h> #include <queue> using namespace std; struct Coordinate { int x,y,step; // 优先队列 friend bool operator<(Coordinate c1,Coordinate c2) { return c2.step<c1.step; } }; // 存储路径 struct Path { int x,y,step; }path[101][101]; int m,n,ans; bool isfind; // 判断能否走到终点 int dis[4][2]={{0,1},{1,0},{0,-1},{-1,0}}; // 四个方向 char map[101][101]; // 存储地图 bool visit[101][101]; // 判断是否走过 // 判断越界、墙、是否已经经过 等问题 bool inmap(int x,int y) { if(x<0 || y<0 || x>=m || y>=n) return 1; if(visit[x][y]==1 || map[x][y]==‘X‘) return 1; return 0; } // 输出 void show(int a,int b,int t) { if(t==1) printf("%ds:(%d,%d)->(%d,%d)\n",t,path[a][b].x,path[a][b].y,a,b); else if(path[a][b].step==1) { show(path[a][b].x,path[a][b].y,t-1); printf("%ds:(%d,%d)->(%d,%d)\n",t,path[a][b].x,path[a][b].y,a,b); } else { --path[a][b].step; show(a,b,t-1); printf("%ds:FIGHT AT (%d,%d)\n",t,a,b); } } // BFS 广搜 void bfs(void) { memset(visit,0,sizeof(visit)); priority_queue <Coordinate> cd; Coordinate p,next; int i; p.x=0,p.y=0,p.step=0; visit[p.x][p.y]=1; cd.push(p); while(!cd.empty()) { p=cd.top(); // 优先队列,所以这块不是cd.front()了 cd.pop(); if(p.x==m-1 && p.y==n-1) { ans=p.step; isfind=1; return; } for(i=0;i<4;++i) { next.x=p.x+dis[i][0]; next.y=p.y+dis[i][1]; if(inmap(next.x,next.y)) continue; else if(map[next.x][next.y]==‘.‘) { // 记录之前该点之前的点 path[next.x][next.y].x=p.x; path[next.x][next.y].y=p.y; path[next.x][next.y].step=1; next.step=p.step+1; visit[next.x][next.y]=1; cd.push(next); } else { // 记录之前该点之前的点 path[next.x][next.y].x=p.x; path[next.x][next.y].y=p.y; path[next.x][next.y].step=map[next.x][next.y]-‘0‘+1; next.step=p.step+map[next.x][next.y]-‘0‘+1; visit[next.x][next.y]=1; cd.push(next); } } } } int main() { int i,j; while(scanf("%d%d",&m,&n)!=EOF) { isfind=0; for(i=0;i<m;++i) scanf("%s",&map[i]); bfs(); if(!isfind) printf("God please help our poor hero.\nFINISH\n"); else { printf("It takes %d seconds to reach the target position, let me show you the way.\n",ans); show(m-1,n-1,ans); printf("FINISH\n"); } } return 0; }
ACM-BFS之Ignatius and the Princess I ——hdu1026,布布扣,bubuko.com
ACM-BFS之Ignatius and the Princess I ——hdu1026
原文:http://blog.csdn.net/lttree/article/details/19962671