Run ID 作者 问题 语言 测评结果 分数 时间 内存 代码长度 提交时间
434886 陈信宇 26年3月-B组(才俊)D. 基因序列 C++ 解答错误 20 4 MS 2740 KB 924 2026-04-02 16:15:30

Tests(5/25):


#include <bits/stdc++.h> using namespace std; const int MOD = 1000000007; const int MAXN = 2005; long long dp[MAXN][MAXN]={1}; int a[MAXN], b[MAXN]; int main() { int n, m; cin >> n >> m; for (int i = 1; i <= n; i++) { cin >> a[i]; } for (int i = 1; i <= m; i++) { cin >> b[i]; } for (int i = 0; i <= n; i++) { dp[i][0] = 1; } for (int j = 0; j <= m; j++) { dp[0][j] = 1; } for (int i = 1; i <= n; i++) { for (int j = 1; j <= m; j++) { if (a[i] == b[j]) { dp[i][j] = (dp[i-1][j-1] + dp[i-1][j] + dp[i][j-1] - 1) % MOD; } else { dp[i][j] = (dp[i-1][j] + dp[i][j-1] - dp[i-1][j-1]) % MOD; } if (dp[i][j] < 0) { dp[i][j] += MAXN; } } } cout << dp[n][m] << endl; return 0; }


测评信息: