zoukankan      html  css  js  c++  java
  • HDU 3638 Go , SuSu

    HDU_3638

        如果除去怪物的话这个题和普通的BFS走迷宫没太大区别,因此不妨将怪物看得相对分离一点,每到一秒先将怪物的视野处理出来,然后这一秒既不走到怪物的视野内又不走到*的位置即可。

        在处理怪物的视野时,可以先用一个结构体存储怪物的方位,每过一秒就自动更新怪物的方位,再打一个包括4个方向且每个方向上有9个相对位置的表,这样就比较好处理出怪物的视野了。

    #include<stdio.h>
    #include<string.h>
    #include<algorithm>
    #include<queue>
    #define MAXN 60
    int trans[] = {0, 2, 1, 4, 3};
    int dx[] = {0, -1, 1, 0, 0}, dy[] = {0, 0, 0, -1, 1};
    int ex[][9] =
    {
        {0, 0, 0, 0, 0, 0, 0, 0, 0},
        {0, -1, -1, -1, -2, -2, -2, -2, -2},
        {0, 1, 1, 1, 2, 2, 2, 2, 2},
        {0, -1, 0, 1, -2, -1, 0, 1, 2},
        {0, -1, 0, 1, -2, -1, 0, 1, 2}
    };
    int ey[][9] =
    {
        {0, 0, 0, 0, 0, 0, 0, 0, 0},
        {0, -1, 0, 1, -2, -1, 0, 1, 2},
        {0, -1, 0, 1, -2, -1, 0, 1, 2},
        {0, -1, -1, -1, -2, -2, -2, -2, -2},
        {0, 1, 1, 1, 2, 2, 2, 2, 2}
    };
    struct Monster
    {
        int x, y, d;
    }mon[MAXN];
    char b[MAXN];
    int N, M, K, sx, sy, tx, ty, g[MAXN][MAXN], del[MAXN][MAXN], vis[MAXN][MAXN];
    struct Point
    {
        int x, y, t;
        Point(){}
        Point(int _x, int _y, int _t) : x(_x), y(_y), t(_t){}
    };
    inline int inside(int x, int y)
    {
        return x >= 1 && x <= N && y >= 1 && y <= M;
    }
    void moveall()
    {
        int i, x, y;
        for(i = 0; i < K; i ++)
        {
            x = mon[i].x + dx[mon[i].d], y = mon[i].y + dy[mon[i].d];
            if(inside(x, y) && g[x][y]) mon[i].x = x, mon[i].y = y;
            else mon[i].d = trans[mon[i].d];
        }
    }
    void delblock()
    {
        int i, j, x, y;
        for(i = 1; i <= N; i ++)
            for(j = 1; j <= M; j ++) del[i][j] = 1 - g[i][j];
        for(i = 0; i < K; i ++)
            for(j = 0; j < 9; j ++)
            {
                x = mon[i].x + ex[mon[i].d][j], y = mon[i].y + ey[mon[i].d][j];
                if(inside(x, y)) del[x][y] = 1;
            }
    }
    void init()
    {
        int i, j;
        scanf("%d%d", &N, &M);
        for(i = 1; i <= N; i ++)
        {
            scanf("%s", b + 1);
            for(j = 1; j <= M; j ++)
            {
                g[i][j] = b[j] != '*';
                if(b[j]== 'A') sx = i, sy = j;
                else if(b[j] == 'B') tx = i, ty = j;
            }
        }
        scanf("%d", &K);
        for(i = 0; i < K; i ++) scanf("%d%d%d", &mon[i].x, &mon[i].y, &mon[i].d);
    }
    void solve()
    {
        int i, j, x, y, cur, ans = -1;
        cur = -1;
        delblock();
        if(del[sx][sy])
        {
            printf("胜败兵家事不期 卷土重来是大侠\n");
            return ;
        }
        std::queue <Point> q;
        q.push(Point(sx, sy, 0));
        while(!q.empty())
        {
            Point p = q.front();
            q.pop();
            if(p.t > 1000) break;
            if(p.x == tx && p.y == ty)
            {
                ans = p.t;
                break;
            }
            if(p.t > cur)
            {
                cur = p.t;
                for(i = 1; i <= N; i ++)
                    for(j = 1; j <= M; j ++) vis[i][j] = 0;
                moveall(), delblock();
            }
            for(i = 0; i < 5; i ++)
            {
                x = p.x + dx[i], y = p.y + dy[i];
                if(inside(x, y) && !del[x][y] && !vis[x][y])
                    vis[x][y] = 1, q.push(Point(x, y, p.t + 1));
            }
        }
        if(ans == -1) printf("胜败兵家事不期 卷土重来是大侠\n");
        else printf("%d\n", ans);
    }
    int main()
    {
        int t, tt;
        scanf("%d", &t);
        for(tt = 1; tt <= t; tt ++)
        {
            init();
            printf("Case %d: ", tt);
            solve();
        }
        return 0;
    }
  • 相关阅读:
    一波骚操作,我把 SQL 执行效率提高了 10,000,000 倍!
    如何优雅地根治null值引起的Bug!
    解锁新姿势:探讨复杂的 if-else 语句“优雅处理”的思路
    39 个奇葩代码注释,看完笑哭了。。。
    只要学会它,再多 Bug 也不怕
    SpringBoot 快速整合Mybatis(去XML化+注解进阶)
    Java 并发异步编程,原来十个接口的活现在只需要一个接口就搞定!
    微服务 2.0 技术栈选型手册
    如何设计 API 接口,实现统一格式返回?
    别在 Java 代码里乱打日志了,这才是打印日志的正确姿势!
  • 原文地址:https://www.cnblogs.com/staginner/p/2659432.html
Copyright © 2011-2022 走看看