首页 > 其他 > 详细

LeetCode "Distinct Subsequences" - TO BE REVISED

时间:2014-08-21 13:03:34      阅读:319      评论:0      收藏:0      [点我收藏+]

A classic and representative DP problem. To be revised later. Quite a few interesting details to think about.

class Solution {
public:
    int numDistinct(string S, string T) {
        int lenS = S.length();
        int lenT = T.length();
        if (lenS < lenT) return 0;
        if (lenS == lenT)
        {
            if (S.compare(T) == 0) return 1;
            else return 0;
        }

        vector<int> dp(lenT + 1, 0);
        dp[0] = 1;            // Point 1

        //    S: i, T: j
        //    if S[i-1] == T[j - 1]
        //        dp[i][j] = dp[i - 1][j] + dp[i - 1][j - 1]
        //    else
        //        dp[i][j] = dp[i - 1][j]
        for (int i = 1; i <= lenS; i ++)
        for (int j = lenT; j >= 1; j--) // Point 2
        {
            if(i < j) continue;
            if (S[i - 1] == T[j - 1])
                dp[j] += dp[j - 1];  // Point 3
        }
        return dp[lenT];
    }
};

LeetCode "Distinct Subsequences" - TO BE REVISED,布布扣,bubuko.com

LeetCode "Distinct Subsequences" - TO BE REVISED

原文:http://www.cnblogs.com/tonix/p/3926771.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!