Escape HDU - 3533

原题链接

考察:搜索

思路:

        预处理有子弹和城堡的坐标,这部分除了暴力没有更好的办法.因为还有一个时间限制,所以需要三维数组.剩下就是BFS.

        剪枝:           1.相同时间的拜访点不必再访问.

                           2.当离终点的曼哈顿距离>能量 不必再走下去.

        注意:城堡处一定要预处理再判断子弹.

 1 #include <iostream>
 2 #include <cstring>
 3 #include <algorithm>
 4 #include <queue>
 5 using namespace std;
 6 const int N = 110,INF = 0x3f3f3f3f,M = 1010;
 7 typedef pair<int,int> PII;
 8 struct Castle{
 9     int dir,T,v,x,y;
10 }ca[N];
11 struct Node{
12     int x,y,t;
13 };
14 int m,n,k,d;
15 bool vis[N][N][M],bullet[N][N][M];
16 char op[2];
17 string dirs = "NSWE";
18 int xx[5] ={-1,1,0,0,0},yy[5] = {0,0,-1,1,0};
19 void init()
20 {
21     for(int i=1;i<=k;i++)
22     {
23         int dx = ca[i].x,dy = ca[i].y,cnt = 0;
24         while(1)
25         {
26             int sx = dx,sy = dy;
27             dx = dx+xx[ca[i].dir]*ca[i].v,dy = dy+yy[ca[i].dir]*ca[i].v;
28             cnt++;
29             if(dx<0||dy<0||dx>m||dy>n||bullet[dx][dy][0]) break;
30             bool ok =1;
31             while(sx!=dx||sy!=dy)
32             {
33                 sx = sx+xx[ca[i].dir],sy = sy+yy[ca[i].dir];
34                 if(bullet[sx][sy][0]) {ok = 0;break;}
35             }
36             if(!ok) break;
37         //    printf("%d %d %d被子弹%d\n",dx,dy,cnt,i);
38             int s = cnt;
39             while(s<=d)
40             {
41                 bullet[dx][dy][s] = 1;
42                 s+=ca[i].T;
43             }
44         }
45     }
46 }
47 int bfs()
48 {
49     queue<Node> q;
50     Node ns; ns.x = 0,ns.y= 0;
51     ns.t = 0;
52     q.push(ns);
53     vis[0][0][0] =1;
54     while(q.size())
55     {
56         Node it = q.front();
57         q.pop();
58         int x=  it.x,y = it.y,ti = it.t;
59         if(x==m&&y==n) return ti;
60         if(ti>=d) continue;
61         for(int i=0;i<5;i++)
62         {
63             int dx = x+xx[i],dy = y+yy[i];
64             if(ti+1<d&&dx>=0&&dx<=m&&dy>=0&&dy<=n&&!vis[dx][dy][ti+1]&&!bullet[dx][dy][ti+1])
65             {
66                 if(bullet[dx][dy][0]) continue;
67                 if(ti+m-dx+n-dy>d) continue;
68                 Node news = {dx,dy,ti+1};
69                 vis[dx][dy][ti+1] = 1;
70                 q.push(news);
71             }
72         }
73     }
74     return -1;
75 }
76 int main()
77 {
78     while(scanf("%d%d%d%d",&m,&n,&k,&d)!=EOF)
79     {
80         memset(vis,0,sizeof vis);
81         memset(bullet,0,sizeof bullet);
82         for(int i=1;i<=k;i++)
83         {
84             scanf("%s%d%d%d%d",op,&ca[i].T,&ca[i].v,&ca[i].x,&ca[i].y);
85             int idx = dirs.find(op[0]);
86             ca[i].dir = idx;
87             bullet[ca[i].x][ca[i].y][0] = 1;
88         }
89         init();
90         int sc = bfs();
91         if(sc!=-1) printf("%d\n",sc);
92         else puts("Bad luck!");
93     }
94     return 0;
95 }

 

posted @ 2021-04-22 08:40  acmloser  阅读(34)  评论(0编辑  收藏  举报