记录编号 |
512647 |
评测结果 |
AAAAAAAAAA |
题目名称 |
[USACO Dec08] 花园栅栏 |
最终得分 |
100 |
用户昵称 |
梦那边的美好ET |
是否通过 |
通过 |
代码语言 |
C++ |
运行时间 |
0.014 s |
提交时间 |
2018-10-05 20:37:57 |
内存使用 |
0.65 MiB |
显示代码纯文本
#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;
}