码迷,mamicode.com
首页 > 其他好文 > 详细

codeforces D - Arthur and Walls

时间:2015-03-29 12:02:59      阅读:108      评论:0      收藏:0      [点我收藏+]

标签:

这题说的是给了一个矩阵,必须让.连接起来的图形变成矩形,2000*2000的矩形,那么我们就可以知道了,只要是存在一个有点的区域应该尽量将他削为矩形,那么将这个图形进行缩放,最后我们知道只要存在一个2*2 的矩形中有1个是*就必须将这个*号去掉。 采用bfs去做

 1 #include <iostream>
 2 #include <algorithm>
 3 #include <string.h>
 4 #include <cstdio>
 5 #include <queue>
 6 using namespace std;
 7 const int maxn = 2005;
 8 char ma[maxn][maxn];
 9 int num[maxn][maxn];
10 bool inq[maxn*maxn];
11 int tx[]={  0,-1, -1, -1, 0, 1, 1, 1 ,0};
12 int ty[]={ -1,-1,  0,  1, 1, 1, 0,-1 , -1};
13 int main()
14 {
15       int n,m;
16      while(scanf("%d%d",&n,&m)==2){
17             queue<int>Q;
18          for(int i=0; i<n; i++){
19             scanf("%s",ma[i]);
20             for(int j=0; j<m; j++)
21                  if(ma[i][j]==.) {
22                    Q.push(i*m+j);
23                  }
24           }
25          while(!Q.empty()){
26              int id = Q.front(); Q.pop();
27              int xx = id/m, yy=id%m;
28              for(int i =0; i<8; i+=2){
29                  int sum=0,loc=-1;
30                  for(int j=i; j<i+3; j++){
31                         int dx = xx + tx[j];
32                  int dy = yy + ty[j];
33                  if(dx<0||dx>=n ||dy>=m||dy<0) 
34                     sum=4;
35                  if(ma[dx][dy]==*)
36                     sum++,loc=dx*m+dy;
37                  if(sum>1)break;
38                  }
39                  if(sum==1){
40                          ma[loc/m][loc%m]=.; Q.push(loc);
41                  }
42              }
43          }
44          for(int i=0; i<n; i++)
45              printf("%s\n",ma[i]);
46      }
47     return 0;
48 }

 

codeforces D - Arthur and Walls

标签:

原文地址:http://www.cnblogs.com/Opaser/p/4375457.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!