• HDU 1728 逃离迷宫


    逃离迷宫

    Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
    Total Submission(s): 27173    Accepted Submission(s): 6622


    Problem Description
      给定一个m × n (m行, n列)的迷宫,迷宫中有两个位置,gloria想从迷宫的一个位置走到另外一个位置,当然迷宫中有些地方是空地,gloria可以穿越,有些地方是障碍,她必须绕行,从迷宫的一个位置,只能走到与它相邻的4个位置中,当然在行走过程中,gloria不能走到迷宫外面去。令人头痛的是,gloria是个没什么方向感的人,因此,她在行走过程中,不能转太多弯了,否则她会晕倒的。我们假定给定的两个位置都是空地,初始时,gloria所面向的方向未定,她可以选择4个方向的任何一个出发,而不算成一次转弯。gloria能从一个位置走到另外一个位置吗?
     
    Input
      第1行为一个整数t (1 ≤ t ≤ 100),表示测试数据的个数,接下来为t组测试数据,每组测试数据中,
      第1行为两个整数m, n (1 ≤ m, n ≤ 100),分别表示迷宫的行数和列数,接下来m行,每行包括n个字符,其中字符'.'表示该位置为空地,字符'*'表示该位置为障碍,输入数据中只有这两种字符,每组测试数据的最后一行为5个整数k, x1, y1, x2, y2 (1 ≤ k ≤ 10, 1 ≤ x1, x2 ≤ n, 1 ≤ y1, y2 ≤ m),其中k表示gloria最多能转的弯数,(x1, y1), (x2, y2)表示两个位置,其中x1,x2对应列,y1, y2对应行。
     
    Output
      每组测试数据对应为一行,若gloria能从一个位置走到另外一个位置,输出“yes”,否则输出“no”。
     
    Sample Input
    2 5 5
    ...**
    *.**.
    .....
    .....
    *....
    1 1 1 1 3
    5 5
    ...**
    *.**.
    .....
    .....
    *....
    2 1 1 1 3
     
    Sample Output
    no yes
     bfs就可以了,注意只有方向改变了才会加1;
    此时标记数组就十分重要
    #include <iostream>
    #include <cstdio>
    #include <cstring>
    #include <queue>
    #include <cmath>
    #include <vector>
    #include <set>
    #include <map>
    #include <algorithm>
    using namespace std;
    typedef long long ll;
    int dir[4][2]={{0,1},{0,-1},{1,0},{-1,0}};
    int vis[110][110],n,m;
    char a[110][110];
    int k,xl,xo,yl,yo,xx,yy,kk,hh;
    struct node
    {
        int x,y,step;
    }ans,pos;
    void bfs(int u,int b,int A,int B,int C)
    {
        memset(vis,0,sizeof(vis));;
        queue<node>q;
        ans.x=u;
        ans.y=b;
        ans.step=-1;
        q.push(ans);
        vis[u][b]=1;
        while(q.empty()==0)
        {
            pos=q.front();
            q.pop();
            if(pos.x==A && pos.y==B && pos.step<=C)
            {
                cout<<"yes"<<endl;
                return;
            }
            for(int i=0;i<4;i++)
            {
                xx=pos.x+dir[i][0];
                yy=pos.y+dir[i][1];
                while((xx>=1 && xx<=n)&&(yy>=1 && yy<=m) && a[xx][yy]!='*')
                {
                    if(vis[xx][yy]==0)
                    {
                       ans.x=xx;
                       ans.y=yy;
                       ans.step=pos.step+1;
                       vis[xx][yy]=1;
                       q.push(ans);
                    }
                    xx+=dir[i][0];
                    yy+=dir[i][1];
                }
            }
        }
        cout<<"no"<<endl;
    }
    int main()
    {
        int t;
        cin>>t;
        while(t--)
        {
            cin>>n>>m;
            for(int i=1;i<=n;i++)
            {
                for(int j=1;j<=m;j++)
                {
                    cin>>a[i][j];
                }
            }
            cin>>k>>yl>>xl>>yo>>xo;
            bfs(xl,yl,xo,yo,k);
        }
        return 0;
    }
    Source
  • 相关阅读:
    DateGridView 分页显示
    DataGridView 隔行显示不同的颜色
    DataGridview 绘制行序号
    DataGrridView 当前行显示不同颜色
    右键删除行
    【bzoj2763】[JLOI2011]飞行路线 分层图最短路
    【bzoj1143】[CTSC2008]祭祀river Floyd+网络流最小割
    【bzoj1029】[JSOI2007]建筑抢修 贪心+堆
    【bzoj1054】[HAOI2008]移动玩具 Bfs
    【bzoj1911】[Apio2010]特别行动队 斜率优化dp
  • 原文地址:https://www.cnblogs.com/shinianhuanniyijuhaojiubujian/p/7122134.html
Copyright © 2020-2023  润新知