Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
114362 | 陈家宝 | 不同路径 | C++ | 解答错误 | 0 | 0 MS | 264 KB | 621 | 2023-12-07 13:20:51 |
#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; }