poj2251(bfs坑爹的领悟)

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

你可能感兴趣的:(递归,队列,DFS)