uva 532

4 篇文章 0 订阅

#include<iostream>

#include<queue>

#include<algorithm>

#include<map>

#include<string.h>

#include<math.h>

#include<stdio.h>

#include <iomanip>

#include <stack>

#include <vector>

#include <sstream>

using namespace std;


bool used[31][31][31];

vector<vector<string>>graph;

int level,row,column;


int dl[]={0,0,0,0,1,-1};

int dr[]={-1,1,0,0,0,0};

int dc[]={0,0,-1,1,0,0};


struct station

{

    

    int L;

    int R;

    int C;

    int num;

    

    station(int x, int y, int z, int NUM)

    {

        L=x;

        R=y;

        C=z;

        num=NUM;

    }

    

};


void Bfs(int a,int b, int c)

{

    queue<station> que;

    

    que.push(station(a,b,c,0));

    memset(used,false,sizeof(used));

    

    used[a][b][c]=true;

    int levels,rows,columns;

    

    int j,k,l;

    

    while(!que.empty())

    {

        station temp=que.front();

        que.pop();

        

        j=temp.L;

        k=temp.R;

        l=temp.C;

        if(graph[j][k][l]=='E')

        {

            printf("Escaped in %d minute(s).\n", temp.num);

            return;

        }

        

        for(int i=0;i<6;i++)

        {

            levels=j+dl[i];

            rows=k+dr[i];

            columns=l+dc[i];

            if(levels>=0 && levels<level && rows>=0 && rows<row && columns>=0 && columns<column && !used[levels][rows][columns] && graph[levels][rows][columns]!='#')

            {

                que.push(station(levels,rows,columns,temp.num + 1));

                used[levels][rows][columns]=true;

            }

        }

        

    }

    printf("Trapped!\n");

    return;

}


int main(){

    

    vector<string> v_str;

    string s;

    int l,r,c;

    while(scanf("%d%d%d", &level, &row, &column)==3 && (level || row||column))

    {

       {

        graph.clear();

        for(int i=0;i<level;i++)

        {

            

            v_str.clear();

            for(int j=0;j<row;j++)

            {

                cin>>s;

                v_str.push_back(s);

            }

            graph.push_back(v_str);

        }

        for(int i=0;i<level;i++)

            for(int j=0;j<row;j++)

                for(int k=0;k<column;k++)

                    if(graph[i][j][k]=='S')

                    {

                        l = i;

                        r= j;

                        c= k;

                        

                        goto exit;

                    }

       }

    exit:

        Bfs(l,r,c);

    }

    return 0;

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值