nefu 1191 平行宇宙 (bfs)

Description

小k是时空贸易者,他经常在两个平行宇宙之间往来经商,现在他要从S点到达E点,问最少需要多长时间。(已知小k在同一个宇宙中只能向上下左右四个方向移动,每次移动需要1个单位时间,且不能在危险小行星带'#'中移动,遇到黑洞'O'时,他会被瞬间吸入另一个宇宙的对应的同一位置,比如从一个宇宙的黑洞处(2,2)必须且只能移动到另一个宇宙的(2,2)位置)

Input

多组输入数据,每组数据第一行包含两个整数n,m(2<=n,m<=1000),表示两个宇宙的大小。
接下来n行表示第一个宇宙,再接下来n行表示第二个宇宙。

Output

每组数据输出一个整数,表示最短时间,如果不能到达目的地,输出-1

Sample Input

4 6
#S##E#
#.##..
#.O.#.
#####.

######
#.####
#..O##
##...O

Sample Output

11

// 其实这题不难,但是要注意细节问题

#include <iostream>
#include <cstring>
#include <cstdio>
#include <queue>
using namespace std;

char data[2][1005][1005];
int visit[2][1005][1005];
int ki,kj,kk,ei,ej,ek;
int n,m;
int to[4][2]={{0,1},{0,-1},{1,0},{-1,0}};

struct node
{
    int i;
    int j;
    int k;
    int time;
};

int go(int i,int j,int k)
{
    if(j>=0&&j<n&&k>=0&&k<m&&data[i][j][k]!='#')
    return 1;
    return 0;
}

void bfs()
{
    node st,ed;
    queue <node> q;
    st.i=ki;
    st.j=kj;
    st.k=kk;
    st.time=0;
    memset(visit,0,sizeof(visit));
    visit[ki][kj][kk]=1;
    q.push(st);
    while(!q.empty())
    {
        st=q.front();
        q.pop();
        if(st.i==ei&&st.j==ej&&st.k==ek)
        {
            cout<<st.time<<endl;
            return ;
        }
        if(data[st.i][st.j][st.k]=='O')
        {
            int t=1;
            if(st.i==1)
            t=0;
            if(data[t][st.j][st.k]!='O'&&data[t][st.j][st.k]!='#'&&visit[t][st.j][st.k]==0)
            {
                //O的对面是O或#时不能走
                st.i=t;
                visit[t][st.j][st.k]=1;
            }
            else continue;//看队列中的下一个
        }
        for(int i=0;i<4;i++)
        {
            ed.i=st.i;
            ed.j=st.j+to[i][0];
            ed.k=st.k+to[i][1];
            if(go(ed.i,ed.j,ed.k)&&visit[ed.i][ed.j][ed.k]==0)
            {
                visit[ed.i][ed.j][ed.k]=1;
                ed.time=st.time+1;
                q.push(ed);
            }
        }
    }
    cout<<"-1"<<endl;
    return ;
}

int main()
{
    while(cin>>n>>m)
    {
        for(int i=0;i<2;i++)
        {
            for(int j=0;j<n;j++)
            {
                scanf("%s",data[i][j]);//减少时间
                for(int k=0;k<m;k++)
                {
                    if(data[i][j][k]=='S')
                    {
                        ki=i;kj=j;kk=k;
                    }
                    if(data[i][j][k]=='E')
                    {
                        ei=i;ej=j;ek=k;
                    }
                }
            }
        }
        bfs();
    }
    return 0;
}

 


posted @ 2016-09-07 18:02  邻家那小孩儿  阅读(224)  评论(0编辑  收藏  举报