LeetCode115. 不同的子序列——字符串类动态规划

本文探讨了正向动态规划和反向动态规划在计算字符串s中与字符串t匹配子序列的唯一数目上的高效实现,通过空间和时间复杂度的优化,展示了如何利用这两种方法解决此类问题,并给出了相应的代码示例。

一、正向动态规划及其优化

class Solution {
   
   
public:
    int numDistinct(string s, string t) 
    {
   
   
        /*
        定义f(i,j)为s串的前i个字符的子序列中t的前j个字符出现的个数
        对新增进来的第i个字符,
        1.可以选择让他拼凑t的第j个字符(如果s[i - 1] == t[j - 1])
          这样就让s串的前i-1个字符只要拼凑t串的前j-1个字符就行 拼凑的方法数为f(i - 1,j - 1)
        2.也可以不让他拼凑t的第j个字符
          这样就让s串的前i-1个字符拼凑t串的前j个字符,拼凑的方法数为f(i - 1,j)
        所以状态转移方程为:
        if (s[i - 1] == t[j - 1]),f(i,j) = f(i - 1,j - 1) + f(i - 1, j)
        else f(i, j) = f(i - 1, j)
        考虑初始条件
        f(0,0) = 1 (空串凑空串 方法唯一) 
        f(i,0) = 1 (凑空串就只能拿空串凑 空串相当于空集,是唯一的)
        f(0,j) = 0 (空串什么也凑不出来)
        */
        int slen = s.size();
        int tlen = t.size();
        vector<vector<unsigned long long>> dp(slen + 1, vector<unsigned long long>(tlen + 1));
        for (auto& e : dp[0])
        {
   
   
            e = 0;
        }
        for (int i = 0; i <= slen; ++i)
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值