zoukankan      html  css  js  c++  java
  • HDU

    题意:一个人从(0,0)跑到(n,m),只有k点能量,一秒消耗一点,在图中有k个炮塔,给出炮塔的射击方向c,射击间隔t,子弹速度v,坐标x,y  ,问这个人能不能安全到达终点(且可以待在原地)
    m,n,k和d(2 <= m,n <= 100,0 <= k <= 100,m + n <= d <= 1000)。 m和n是战场的大小,k是城堡的数量,d是Little A最初拥有的能量单位
    思路:看当人位于某个点的时候,其四个方向是否有炮塔,这个炮塔是都向人的方向射击,然后再看子弹是否刚好位于这个坐标即可
    同时用state[x][y][time]标记,对于time时刻,人位于x,y的情况只需要访问一次,这是唯一的

    完整代码:

    #include <iostream>
    #include <cstdio>
    #include <cstring>
    #include <cmath>
    #include <algorithm>
    #include <vector>
    #include <queue>
    #include <string>
    using namespace std;
    const int MAXN = 105;

    bool M[MAXN][MAXN], st[MAXN][MAXN][1010];
    bool vis[MAXN][MAXN][1010];

    int mov[5][2] = {-1,0, 1,0, 0,1, 0,-1,0 ,0};
    int n, m, k, d;

    struct Castle
    {
        int dir, x, y, t,v;
    }Castle[MAXN];

    struct node
    {
        int x, y, step;
    };

    void init()
    {
        memset(st, 0,sizeof(st));
        for(int i = 0; i<k; i++)    //枚举城堡
        {
            for(int j = 0; j<=d; j += Castle[i].t)    //模拟一颗子弹
            {
                for(int k = 1; ; k++)   //枚举路程
                {
                    int x = Castle[i].x + mov[Castle[i].dir][0]*k;
                    int y = Castle[i].y + mov[Castle[i].dir][1]*k;
                    if(x<0 || x>n || y<0 ||y>m || M[x][y]) break;
                    if(k%Castle[i].v==0)    //到达整点时刻,更新st数组
                        st[x][y][j+k/Castle[i].v] = true;
                }
            }
        }
    }

    queue<node>que;
    int bfs()
    {
        memset(vis ,0,sizeof(vis));
        while(!que.empty()) que.pop();
        node now, tmp;
        now.x = now.y = 0;
        now.step = 0;
        vis[0][0][0] = true;
        que.push(now);

        while(!que.empty())
        {
            now = que.front();
            que.pop();

            if(now.step>d)  //累死了
                return -1;
            if(now.x==n && now.y==m)    //顺利回营
                return now.step;

            for(int i = 0; i<5; i++)
            {
                tmp.x = now.x + mov[i][0];
                tmp.y = now.y + mov[i][1];
                tmp.step = now.step + 1;
                if(tmp.x>=0 && tmp.x<=n && tmp.y>=0 && tmp.y<=m && !M[tmp.x][tmp.y]
                   && !st[tmp.x][tmp.y][tmp.step] && !vis[tmp.x][tmp.y][tmp.step])
                {
                    vis[tmp.x][tmp.y][tmp.step] = 1;
                    que.push(tmp);
                }
            }
        }
        return -1;
    }

    int main()
    {
        while(scanf("%d%d%d%d",&n,&m,&k,&d)!=EOF)
        {
            memset(M, 0,sizeof(M));
            char t;
            for(int i = 0; i<k; i++)
            {
                getchar();
                scanf("%c%d%d%d%d",&t, &Castle[i].t, &Castle[i].v, &Castle[i].x, &Castle[i].y);
                if(t=='N') Castle[i].dir = 0;
                if(t=='S') Castle[i].dir = 1;
                if(t=='E') Castle[i].dir = 2;
                if(t=='W') Castle[i].dir = 3;
                M[Castle[i].x][Castle[i].y] = 1;
            }
            init();
            int ans = bfs();
            if(ans==-1)
                puts("Bad luck!");
            else
                printf("%d ", ans);
        }
    }
  • 相关阅读:
    对于未来的搜索引擎的思考!
    [转]《C陷阱与缺陷》读书笔记——前车之覆,后车之鉴
    C语言深度解剖笔记
    感觉压力挺大的!!
    发现中国的代理服务器很少
    我的博客搬家了
    [转]22+1条经典的编程引言
    [转]想象五年之后的你
    什么叫做卷积
    《30天自制操作系统》读书笔记(1)读前感
  • 原文地址:https://www.cnblogs.com/Tianwell/p/11278270.html
Copyright © 2011-2022 走看看