uva 11624 Fire!(搜索)

开始刷题啦= = 痛并快乐着,学到新东西的感觉其实比看那些无脑的小说、电视剧有意思多了

bfs裸体,关键是先把所有的着火点放入队列,分开一个一个做bfs会超时的

发现vis[][]是多余的,完全可以用num[][]代替了,不过不提交了。。。

uva的submission error跳得我蛋疼,可是介于管理员Carlos及时回复了,还是理解人家吧

  1 #include<cstdio>
  2 #include<cstring>
  3 
  4 const int MAXN=1111;
  5 
  6 struct P{
  7     int x,y;
  8     int c;
  9 };
 10 
 11 P que[MAXN*MAXN];
 12 char mp[MAXN][MAXN];
 13 int num[MAXN][MAXN],vis[MAXN][MAXN];
 14 
 15 int dir[4][2]={1,0,-1,0,0,1,0,-1};
 16 int n,m,flog;
 17 int xi[MAXN],yi[MAXN];
 18 
 19 void bfs(int l,int r)
 20 {
 21     while(l<r)
 22     {
 23         int x=que[l].x;
 24         int y=que[l].y;
 25         int c=que[l++].c;
 26         num[x][y]=c;
 27         for(int i=0;i<4;i++)
 28         {
 29             int dx=x+dir[i][0];
 30             int dy=y+dir[i][1];
 31 
 32             if(dx<0||dy<0||dx>=n||dy>=m){
 33                 if(!flog){
 34                     flog=1;
 35                     que[0].c=c;
 36                 }
 37                 continue;
 38             }
 39             if(!vis[dx][dy]&&mp[dx][dy]!='#'&&(num[dx][dy]>c+1||num[dx][dy]==-1)){
 40                 vis[dx][dy]=1;
 41                 que[r].x=dx;
 42                 que[r].y=dy;
 43                 que[r++].c=c+1;
 44             }
 45         }
 46     }
 47 }
 48 
 49 int main()
 50 {
 51     int T,x,y;
 52     int i,j,k;
 53     int l,r;
 54 
 55     scanf("%d",&T);
 56     while(T--)
 57     {
 58         int tot=0;
 59         scanf("%d%d",&n,&m);
 60         for(i=0;i<n;i++)
 61         {
 62             getchar();
 63             for(j=0;j<m;j++)
 64             {
 65                 scanf("%c",&mp[i][j]);
 66                 if(mp[i][j]=='J'){
 67                     x=i;
 68                     y=j;
 69                 }
 70                 if(mp[i][j]=='F'){
 71                     xi[tot]=i;
 72                     yi[tot++]=j;
 73                 }
 74             }
 75         }
 76 
 77         memset(num,-1,sizeof(num));
 78         memset(vis,0,sizeof(vis));
 79         for(i=0;i<tot;i++)
 80         {
 81             vis[xi[i]][yi[i]]=1;
 82             que[i].x=xi[i];
 83             que[i].y=yi[i];
 84             que[i].c=1;
 85         }
 86         bfs(0,tot);
 87 
 88         memset(vis,0,sizeof(vis));
 89         flog=0;
 90         que[0].x=x;
 91         que[0].y=y;
 92         que[0].c=1;
 93         bfs(0,1);
 94         
 95         if(flog){
 96             printf("%d\n",que[0].c);
 97         }else {
 98             printf("IMPOSSIBLE\n");
 99         }
100     }
101     return 0;
102 }
103 /*
104 8 8
105 ........
106 ..F...F.
107 ....J...
108 ...F....
109 ......F.
110 ........
111 ........
112 ........
113 
114 5 5
115 .....
116 .###.
117 .#J#.
118 .###.
119 .....
120 
121 5 5
122 .....
123 .#F#.
124 .FJF.
125 .#F#.
126 .....
127 
128 5 5
129 ....F
130 .#.#.
131 ..J..
132 .#.#.
133 F....
134 
135 5 5
136 ....F
137 .#.#.
138 ..J..
139 .#.#.
140 .....
141 */
View Code

 

posted @ 2013-07-31 19:03  Thousand Sunny  阅读(209)  评论(0编辑  收藏  举报