动态规划 Leetcode 392 判断子序列

判断子序列

Leetcode 392

学习记录自代码随想录

要点:1.dp[i]以nums[i-1]结尾时最大子数组和,此时不用初始化dp[0]为nums[0],如果为nums[i]结尾则需要初始化;

2.递推公式: dp[i] = max(nums[i-1], dp[i-1] + nums[i-1]);

3.返回的是dp的最大值

cpp 复制代码
class Solution {
public:
    bool isSubsequence(string s, string t) {
        int m = s.size(), n = t.size();
        // s为空则一定为真
        if(m == 0) return true;
        // 1.dp[i][j]长度为s[0:i-1]和t[0:j-1]时最大重复子序列长度
        vector<vector<int>> dp(m+1, vector<int>(n+1, 0));
        // 2.递推公式:if(s[i-1] == t[j-1]) dp[i][j] = dp[i-1][j-1] + 1;
        //            else dp[i][j] = max(dp[i-1][j], dp[i][j-1]);
        // 3.dp数组初始化
        // 4.遍历顺序:正向遍历
        for(int i = 1; i < m+1; i++){
            for(int j = 1; j < n+1; j++){
                if(s[i-1] == t[j-1]) dp[i][j] = dp[i-1][j-1] + 1;
                else dp[i][j] = max(dp[i-1][j], dp[i][j-1]);
                if(dp[i][j] == m) return true;
            }
        }
        // 5.举例推导dp数组
        return false;
    }
};
相关推荐
leobertlan4 小时前
好玩系列:用20元实现快乐保存器
android·人工智能·算法
青梅橘子皮5 小时前
C语言---指针的应用以及一些面试题
c语言·开发语言·算法
_深海凉_6 小时前
LeetCode热题100-有效的括号
linux·算法·leetcode
被开发耽误的大厨8 小时前
1、==、equals、hashCode底层原理?重写场景?
算法·哈希算法
WolfGang0073219 小时前
代码随想录算法训练营 Day38 | 动态规划 part11
算法·动态规划
松☆10 小时前
C++ 算法竞赛题解:P13569 [CCPC 2024 重庆站] osu!mania —— 浮点数精度陷阱与 `eps` 的深度解析
开发语言·c++·算法
jr-create(•̀⌄•́)10 小时前
正则化和优化算法区别
pytorch·深度学习·神经网络·算法
li星野11 小时前
刷题:数组
数据结构·算法
tankeven12 小时前
HJ182 画展布置
c++·算法
CS_Zero14 小时前
无人机路径规划算法——EGO-planner建模总结—— EGO-planner 论文笔记(一)
论文阅读·算法·无人机