poj2251(bfs坑爹的领悟)
来源:互联网 发布:火线精英刷枪软件 编辑:程序博客网 时间:2024/06/06 03:50
真么想到这么基础一道题 给我了这么多坑爹的领悟。。。
1.坑爹的是竟然把这题目分类在了深搜里面,然后我就屁颠屁颠深搜,妈蛋TLE,后来总结迷宫类问题果断bfs简单多了,dfs还有TLE的风险,一不小心就递归的超时。
2.坑爹队列的结构体数组开小了,wrong的我不想做其他题了。(细心,或者用STL里面队列)。
3.还有一点就是,字符串输入的问题,以后都用scanf(“%s”,…)读,考虑一个一个字符读回车都读进去,各种麻烦。。。。
题意就是 :一个立体的迷宫,输出最短路径。
用一个三维字符串数组模拟 迷宫,广搜,。
先来DFS的TLE代码
#include<cstdio>#include<cstring>#include<algorithm>#include<iostream>using namespace std;int L,R,C,startx,starty,startz,endx,endy,endz,num,flag=0,Min=100000000;int next[6][3]={{-1,0,0},{0,0,1},{0,1,0},{0,0,-1},{0,-1,0},{1,0,0}};char a[51][51][51];int book[51][51][51]={0};void dfs(int x,int y,int z,int step){ if(x==endx&&y==endy&&z==endz) { if(step<Min) { Min=step; } flag=1; return; } for(int i=0;i<6;i++) { int tx=x+next[i][0]; int ty=y+next[i][1]; int tz=z+next[i][2]; if(tx<0||ty<0||tz<0||tx>=L||ty>=R||tz>=C) continue; if(a[tx][ty][tz]!='#'&&book[tx][ty][tz]==0) { book[tx][ty][tz]=1; dfs(tx,ty,tz,step+1); book[tx][ty][tz]=0; } } return;}int main(){ while(~scanf("%d %d %d",&L,&R,&C)&&L&&R&&C) { for(int i=0;i<L;i++) { getchar(); for(int j=0;j<R;j++) { scanf("%s",a[i][j]); for(int k=0;k<C;k++) { if(a[i][j][k]=='S') { startx=i; starty=j; startz=k; } if(a[i][j][k]=='E') { endx=i; endy=j; endz=k; } } } } memset(book,0,sizeof(book)); flag=0; book[startx][starty][startz]=1; dfs(startx,starty,startz,0); if(flag) printf("Escaped in %d minute(s)\n",Min); else printf("Trapped!\n"); }}
bfs ac代码
#include<cstdio>#include<cstring>#include<iostream>using namespace std;struct node{ int x; int y; int z; int s;};struct node queue[40000];char a[31][31][31];int book[60][60][60];int next[6][3]={{-1,0,0},{0,0,1},{0,1,0},{0,0,-1},{0,-1,0},{1,0,0}};int main(void){ int L,R,C,startx,starty,startz; while(~scanf("%d %d %d",&L,&R,&C)&&L&&R&&C) { int flag=0; memset(book,0,sizeof(book)); for(int i=0;i<L;i++) { getchar(); for(int j=0;j<R;j++) { scanf("%s",a[i][j]); for(int k=0;k<C;k++) { if(a[i][j][k]=='S') { startx=i; starty=j; startz=k; } } } } int head=1,tail=1; queue[tail].x=startx; queue[tail].y=starty; queue[tail].z=startz; queue[tail].s=0; tail++; book[startx][starty][startz]=1; while(head<tail) { for(int i=0;i<6;i++) { int tx=queue[head].x+next[i][0]; int ty=queue[head].y+next[i][1]; int tz=queue[head].z+next[i][2]; if(tx<0||ty<0||tz<0||tx>=L||ty>=R||tz>=C) continue; if((a[tx][ty][tz]=='.'||a[tx][ty][tz]=='E')&&book[tx][ty][tz]==0) { queue[tail].x=tx; queue[tail].y=ty; queue[tail].z=tz; queue[tail].s=queue[head].s+1; tail++; book[tx][ty][tz]=1; } if(a[tx][ty][tz]=='E') { flag=1; break; } } if(flag==1) break; head++; } if(flag) printf("Escaped in %d minute(s).\n",queue[tail-1].s); else printf("Trapped!\n"); } return 0;}
帅杰学长 STL 的
#include<cstdio>#include<cstring>#include<iostream>#include<queue>using namespace std;struct node{ int x; int y; int z; int s; node () {} node(int a,int b,int c,int d):x(a),y(b),z(c),s(d) {}};struct node queue1[10000];char a[41][41][41];int book[31][31][31];int next[6][3]={{-1,0,0},{0,0,1},{0,1,0},{0,0,-1},{0,-1,0},{1,0,0}};int main(void){ int L,R,C,startx,starty,startz; while(~scanf("%d %d %d",&L,&R,&C)&&L&&R&&C) { int flag=0; memset(book,0,sizeof(book)); for(int i=0;i<L;i++) { for(int j=0;j<R;j++) { scanf("%s",a[i][j]); for(int k=0;k<C;k++) { if(a[i][j][k]=='S') { startx=i; starty=j; startz=k; } } } getchar(); } node t(startx,starty,startz,0); queue<node> q; q.push(t); book[startx][starty][startz]=1; int ans; while(!q.empty()) { t=q.front(); q.pop(); for(int i=0;i<6;i++) { int x=t.x+next[i][0]; int y=t.y+next[i][1]; int z=t.z+next[i][2]; if(x<0||y<0||z<0||x>=L||y>=R||z>=C) continue; if((a[x][y][z]=='.'||a[x][y][z]=='E') && book[x][y][z]==0) { node r(x,y,z,t.s+1); q.push(r); book[x][y][z]=1; } if(a[x][y][z]=='E') { ans=t.s+1; flag=1; break; } } if(flag) break; } if(flag) printf("Escaped in %d minute(s).\n",ans); else printf("Trapped!\n"); } return 0;}
0 0
- poj2251(bfs坑爹的领悟)
- POJ2251 三维的bfs
- Dungeon Master(poj2251,bfs)
- poj2251 Dungeon Master (BFS)
- poj2251 bfs
- poj2251 bfs
- POJ2251 BFS
- POJ2251 BFS
- poj2251——Dungeon Master(BFS)
- POJ2251(BFS求最短路)
- poj2251 Dungeon Master(三维bfs)
- poj2251 Dungeon Master (BFS)
- POJ2251 BFS基础题
- Dungeon Master(poj2251,bfs)
- POJ2251:Dungeon Master(BFS)
- poj2251 Dungeon Master bfs
- POJ2251:Dungeon Master(BFS)
- poj2251 Dungeon Master(BFS)
- 在Linux上安装Memcached服务
- x264源代码简单分析:宏块编码(Encode)部分
- Neutron网络入门
- Python编写单片机上位机
- cocos2dx 3.3 + QT5.3制作游戏编辑器
- poj2251(bfs坑爹的领悟)
- SDK的安装和配置
- xib原理
- 第一篇文(写在最前面)
- [其他] 搭建Qt界面的OpenCV开发环境
- linux学习笔记—命令1
- GCC警告选项例解
- 科普 浏览器内核
- JavaWeb编程记录:build-impl.xml:1056: 尚未部署该模块