题解 | #Coincidence#

Coincidence

http://www.nowcoder.com/practice/f38fc44b43cf44eaa1de407430b85e69

/*
描述
Find a longest common subsequence of two strings.
输入描述:
First and second line of each input case contain two strings of lowercase character a…z. There are no spaces before, inside or after the strings. Lengths of strings do not exceed 100.
输出描述:
For each case, output k – the length of a longest common subsequence in one line.
*/

#include<iostream>
#include<string>
#include<vector>

using namespace std;

int main() {
    string strA;
    string strB;
    cin >> strA;
    cin >> strB;
    int n = strA.size(), m = strB.size();
    int** dp = new int* [n+1];
    for (int i = 0; i < n+1; ++i) {
        dp[i] = new int[m+1] {0};
    }
    for (int i = 1; i < n + 1; ++i) {
        for (int j = 1; j < m + 1; ++j) {
            if (strA[i - 1] == strB[j - 1]) {
            // 此时A,B串同时往后移动一位,此为贪心解法,不过此时贪心即为最优解 (optimal solution)
                dp[i][j] = dp[i - 1][j - 1] + 1;        
            }
            else {
            // 此时最大值为以下二者之一:1. A往后移动一位,B不动;2.B往后移动一位,A不动 (因为A[i-1], B[j]和 A[i], B[j-1]均可能匹配,而A[i],B[j]一定不匹配)
                dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]);        
            }
        }
    }
    cout << dp[n][m]<<endl;

    for (int i = 0; i < n + 1; ++i) {
        delete [] dp[i];
    }
    delete [] dp;

    return 0;
}
全部评论

相关推荐

11-08 16:53
门头沟学院 C++
投票
滑模小马达:第三个如果是qfqc感觉还行,我签的qfkj搞电机的,违约金也很高,但公司感觉还可以,听说之前开过一个试用转正的应届生,仅供参考。
点赞 评论 收藏
分享
10-14 23:01
已编辑
中国地质大学(武汉) Java
CUG芝士圈:虽然是网上的项目,但最好还是包装一下,然后现在大部分公司都在忙校招,十月底、十一月初会好找一些。最后,boss才沟通100家,别焦虑,我去年暑假找第一段实习的时候沟通了500➕才有面试,校友加油
点赞 评论 收藏
分享
1 收藏 评论
分享
牛客网
牛客企业服务