1455: [蓝桥杯2019初赛]迷宫

[题目链接] http://oj.ecustacm.cn/problem.php?id=1455

1455: [蓝桥杯2019初赛]迷宫

题目描述
下图给出了一个迷宫的平面图,其中标记为1 的为障碍,标记为0 的为可
以通行的地方。
010000
000100
001001
110000
迷宫的入口为左上角,出口为右下角,在迷宫中,只能从一个位置走到这
个它的上、下、左、右四个方向之一。
对于上面的迷宫,从入口开始,可以按DRRURRDDDR 的顺序通过迷宫,
一共10 步。其中D、U、L、R 分别表示向下、向上、向左、向右走。
对于下面这个更复杂的迷宫(30 行50 列),请找出一种通过迷宫的方式,
其使用的步数最少,在步数最少的前提下,请找出字典序最小的一个作为答案。
请注意在字典序中D 输入
见文件:maze.txt

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
using namespace std;

int m,n;
char Map[31][51];
int vis[30][50];
int dx[4]={1,0,0,-1};
int dy[4]={0,-1,1,0};
char dir[4]={'D','L','R','U'};
struct  node
{
    int x,y,step;
    string str;
    node node1(int xx,int yy,int step1,string s)
    {
        //构造函数不断更新str
        x=xx,y=yy,step=step1,str=s;
    }
};
node pre[100][100];
int judge(int x,int y)
{
    if(x>=0&&x<n&&y>=0&&y<m&&Map[x][y]=='0')
        return 1;
    return 0;  
}
void bfs(node start)
{
    queue<node>q;
    node New,Now;
    q.push(start);
    vis[start.x][start.y]=0;
    while(!q.empty())
    {
        Now=q.front();
        q.pop();
        if(Now.x==n-1&&Now.y==m-1)
        {
            printf("%d\n",Now.step);
            cout<<Now.str<<endl;
            return ;
        }
        for(int i=0;i<4;i++)
        {
            int nx=Now.x+dx[i],ny=Now.y+dy[i];
            if(judge(nx,ny)&&!vis[nx][ny])
            {
                New.x=nx,New.y=ny,New.step=Now.step+1;
                pre[nx][ny].x=Now.x;pre[nx][ny].y=Now.y;
                New.str=Now.str+dir[i];//不断更新字符
                vis[nx][ny]=1;
                q.push(New);
            }
        }
    }
}
void print(node cur)
{
    if(cur.x==0&&cur.y==0)
    {
        printf("(0,0)\n");
        return ;
    }
    print(pre[cur.x][cur.y]);
    printf("(%d,%d)\n",cur.x,cur.y);
}
int main()
{
    int i,j;
    scanf("%d%d",&n,&m);
    for(i=0;i<n;i++)
    {
        for(j=0;j<m;j++)
            cin>>Map[i][j];
    }
    node start;
    start.x=0,start.y=0,start.step=0,start.str="";
    bfs(start);
    node ed;
    ed.x=n-1,ed.y=m-1;
    print(ed);
   // cout<<"DDDDRRURRRRRRDRRRRDDDLDDRDDDDDDDDDDDDRDDRRRURRUURRDDDDRDRRRRRRDRRURRDDDRRRRUURUUUUUUULULLUUUURRRRUULLLUUUULLUUULUURRURRURURRRDDRRRRRDDRRDDLLLDDRRDDRDDLDDDLLDDLLLDLDDDLDDRRRRRRRRRDDDDDDRR"<
    return 0;
}

你可能感兴趣的:(算法之路,搜索,ACM题目)