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