1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
| #include<bits/stdc++.h> using namespace std; int n,a[405][5][5],f[5][5][405][8][8][8][8]; int dx[]={-1,0,-2,0,2,0,1,0,0},dy[]={0,-1,0,-2,0,2,0,1,0}; int dfs(int x,int y,int day,int ex,int sx,int ey,int sy){ if(f[x][y][day][ex][sx][ey][sy]!=-1) return f[x][y][day][ex][sx][ey][sy]; for(int i=x;i<=x+1;i++) for(int j=y;j<=y+1;j++) if(a[day][i][j]==1) return 0; if(ex>=7||sx>=7||ey>=7||sy>=7) return 0; if(day==n) return 1; int ans=0; for(int i=0;i<9;i++){ int tx=x+dx[i],ty=y+dy[i]; if(1<=tx&&tx<=3&&1<=ty&&ty<=3){ int a,b,c,d; if(tx==1&&ty==1)a=0;else a=ex+1; if(tx==3&&ty==1)b=0;else b=sx+1; if(tx==1&&ty==3)c=0;else c=ey+1; if(tx==3&&ty==3)d=0;else d=sy+1; ans|=dfs(tx,ty,day+1,a,b,c,d); } }if(f[x][y][day][ex][sx][ey][sy]==-1) f[x][y][day][ex][sx][ey][sy]=ans; return ans; }int main(){ while(1){ memset(f,-1,sizeof(f)),cin>>n; if(n==0) break; for(int i=1;i<=n;i++) for(int j=1;j<=4;j++) for(int k=1;k<=4;k++) cin>>a[i][j][k]; cout<<dfs(2,2,1,1,1,1,1)<<'\n'; } }
|