CodeForces Round #191 (327D) - Block Tower DFS

    首先将所有的.变为B

    对于一个联通的B区域....可以从边界开始变R..直到只剩下一个B...

    但是直接要找到边界的点..然后逼退到只剩一个B..不方便..不如DFS...从任意一个B进入..回朔的时候将B变为R...保证顺序..


Program:

#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<math.h>
#include<stack>
#include<string.h>
#include<map>
#include<queue>
#define ll long long
#define oo 1000000000
#define pi acos(-1.0)
using namespace std;
struct node
{
        char c;
        int y,x;
}step[1000005];
int n,m,num;
char s[505][505];
bool used[505][505];
void doit(char c,int y,int x)
{
        s[y][x]=c;
        num++;
        step[num].c=c,step[num].y=y,step[num].x=x;
        return;
}
void dfs(int y,int x)
{
        if (s[y][x]!='B' || used[y][x]) return;
        used[y][x]=true;
        if (x>1) dfs(y,x-1);
        if (y>1) dfs(y-1,x);
        if (x<m) dfs(y,x+1);
        if (y<n) dfs(y+1,x);       
        doit('D',y,x),doit('R',y,x);
        return; 
}
int main()
{
        int i,j,t,x,sum;
        bool f; 
        while (~scanf("%d%d",&n,&m))
        {
                for (i=1;i<=n;i++) scanf("%s",s[i]+1);
                num=0;
                for (i=1;i<=n;i++)
                  for (j=1;j<=m;j++)
                    if (s[i][j]=='.') doit('B',i,j);
                sum=0;
                memset(used,false,sizeof(used));
                for (i=1;i<=n;i++)
                   for (j=1;j<=m;j++)
                     if (s[i][j]=='B')
                     {
                            used[i][j]=true;
                            if (j>1) dfs(i,j-1);
                            if (i>1) dfs(i-1,j);
                            if (j<m) dfs(i,j+1);
                            if (i<n) dfs(i+1,j);                                     
                     }
                printf("%d\n",num);
                for (i=1;i<=num;i++) printf("%c %d %d\n",step[i].c,step[i].y,step[i].x);
        }
        return 0;
}


你可能感兴趣的:(CodeForces Round #191 (327D) - Block Tower DFS)