提交时间:2023-12-07 13:20:51

运行 ID: 114362

#include<bits/stdc++.h> using namespace std; int n,m,dp[1005][1005]; bool a[1005][1005]; int main() { cin>>n,m; for(int i=1;i<=n;i++){ for(int j=1;j<=m;j++) cin>>a[i][j]; } for(int i=1;i<=m;i++){ if(a[1][i]==false) dp[1][i]=1; } for(int i=1;i<=n;i++){ if(a[i][1]==false) dp[i][1]=1; } for(int i=2;i<=n;i++){ for(int j=2;j<=m;j++){ if(a[i-1][j]==1&&a[i][j-1]==0) dp[i][j]=dp[i][j-1]; else if(a[i-1][j]==0&&a[i][j-1]==1) dp[i][j]=dp[i-1][j]; else if(a[i-1][j]==0&&a[i][j-1]==0) dp[i][j]=dp[i][j-1]+dp[i-1][j]; } } cout<<dp[n][m]; return 0; }