真么想到这么基础一道题 给我了这么多坑爹的领悟。。。
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;
}