动态规划 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;
    }
};
相关推荐
夏鹏今天学习了吗18 小时前
【LeetCode热题100(87/100)】最小路径和
算法·leetcode·职场和发展
哈哈不让取名字19 小时前
基于C++的爬虫框架
开发语言·c++·算法
Lips61121 小时前
2026.1.20力扣刷题笔记
笔记·算法·leetcode
2501_9413297221 小时前
YOLOv8-LADH马匹检测识别算法详解与实现
算法·yolo·目标跟踪
洛生&21 小时前
Planets Queries II(倍增,基环内向森林)
算法
小郭团队21 小时前
1_6_五段式SVPWM (传统算法反正切+DPWM2)算法理论与 MATLAB 实现详解
嵌入式硬件·算法·matlab·dsp开发
小郭团队21 小时前
1_7_五段式SVPWM (传统算法反正切+DPWM3)算法理论与 MATLAB 实现详解
开发语言·嵌入式硬件·算法·matlab·dsp开发
鱼跃鹰飞21 小时前
Leetcode347:前K个高频元素
数据结构·算法·leetcode·面试
bybitq21 小时前
LeetCode236-二叉树的最近公共祖先(LCA)问题详解-C++
算法·深度优先
啊阿狸不会拉杆1 天前
《数字图像处理》第 7 章 - 小波与多分辨率处理
图像处理·人工智能·算法·计算机视觉·数字图像处理