第22615题 单选
下列关于求解最长公共子序列(LCS)的C++代码的描述中,不正确的是?
while (cin >> s1 >> s2)
{
    memset(dp, 0, sizeof(dp));
    int n1 = strlen(s1), n2 = strlen(s2);
    for (int i = 1; i <= n1; ++i)
        for (int j = 1; j <= n2; ++j)
            if (s1[i - 1] == s2[j - 1])
                dp[i][j] = dp[i - 1][j - 1] + 1;
            else
                dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]);
    cout << dp[n1][n2] << endl;
}
A

代码的时间复杂度为O(n²)

B

代码的空间复杂度为O(n²)

C

空间复杂度已经最优

D

采用了动态规划求解