比赛 20181005 评测结果 AAAAAAAAAA
题目名称 花园栅栏 最终得分 100
用户昵称 梦那边的美好ET 运行时间 0.034 s
代码语言 C++ 内存使用 14.00 MiB
提交时间 2018-10-05 20:38:06
显示代码纯文本
#include<iostream>
#include<cstdio>
#include<string>
#include<cstring>
#include<algorithm>
const int maxn=210;
int G[maxn][maxn],vis[maxn][maxn],dx[maxn],dy[maxn],cnt=0;
void dfs(int x,int y){
    if(x<0||y<0||x>200||y>200) return;
    if(vis[x][y]||G[x][y]) return;
    if((x&1)&&(y&1)) cnt++;
    vis[x][y]=1;
    dfs(x+1,y);dfs(x,y+1);
    dfs(x-1,y);dfs(x,y-1);
	return;
}
int main(){
    freopen("fence.in","r",stdin);
    freopen("fence.out","w",stdout);
    dx[13]=-1;dy[13]= 0;
    dx[22]= 0;dy[22]=-1; 
    dx[18]= 1;dy[18]= 0; 
    dx[4]= 0;dy[4]= 1; 
    int x,y,z;scanf("%d%d%d\n",&y,&x,&z);
    char c;int d;x=(100-x)*2;y=y*2;
    for(int i=1;i<=z;i++){
        scanf("%c%d\n",&c,&d);
        for(int j=0;j<=2*d;j++)G[x+j*dx[c-'A']][y+j*dy[c-'A']]=1;
        x=x+2*d*dx[c-'A'];y=y+2*d*dy[c-'A'];
    }
    for(int i=0;i<=200;i++)if(!vis[0][i]) dfs(0,i); 
    for(int i=0;i<=200;i++)if(!vis[200][i]) dfs(200,i);
    for(int i=0;i<=200;i++)if(!vis[i][0]) dfs(i,0);
    for(int i=0;i<=200;i++)if(!vis[i][200]) dfs(i,200);
    printf("%d\n",100*100-cnt);
    return 0;
}