比赛 |
2024暑假C班集训A |
评测结果 |
AAAAWAAAAT |
题目名称 |
牧场的安排 |
最终得分 |
80 |
用户昵称 |
wzh0425 |
运行时间 |
2.344 s |
代码语言 |
C++ |
内存使用 |
3.52 MiB |
提交时间 |
2024-07-10 09:21:34 |
显示代码纯文本
#include<bits/stdc++.h>
using namespace std;
int m,n,flag,sx,sy,ex,ey,vis[15][15],mapp[15][15],sum;
void dfs(int x,int y){
//cout<<vis[x][y]<<" "<<x<<" "<<y<<endl;
if (x==ex&&y==ey){
sum++;
sum%=100000000;
return;
}
int xx,yy;
if (y==n){
xx=x+1,yy=1;
}else{
xx=x,yy=y+1;
}
if (!vis[xx-1][yy]&&!vis[xx][yy-1]&&mapp[xx][yy]){
for (int i=0;i<=1;i++){
vis[xx][yy]=i;
dfs(xx,yy);
vis[xx][yy]=0;
}
}else{
dfs(xx,yy);
}
}
int main(){
freopen("cowfood.in","r",stdin);
freopen("cowfood.out","w",stdout);
scanf("%d%d",&m,&n);
for (int i=1;i<=m;i++){
for (int j=1;j<=n;j++){
scanf("%d",&mapp[i][j]);
if (mapp[i][j]==1){
if (flag==0){
flag=1;
sx=i,sy=j;
}
ex=i,ey=j;
}
}
}
for (int i=0;i<=1;i++){
vis[sx][sy]=i;
dfs(sx,sy);
vis[sx][sy]=0;
}
printf("%d",sum);
return 0;
}