动态规划 Leetcode 392 判断子序列

判断子序列

Leetcode 392

学习记录自代码随想录

要点:1.dpi以numsi-1结尾时最大子数组和,此时不用初始化dp0为nums0,如果为numsi结尾则需要初始化;

2.递推公式: dpi = max(numsi-1, dpi-1 + numsi-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;
    }
};
相关推荐
通信小呆呆15 小时前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
benben04415 小时前
强化学习之DQN算法族(基于gymnasium开发)
算法
何以解忧,唯有..16 小时前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
想吃火锅100517 小时前
【leetcode】88.合并两个有序数组js
算法
生成论实验室18 小时前
机器人:一个自主运动的系统
人工智能·算法·语言模型·机器人·自动驾驶·agi·安全架构
Qres82118 小时前
算法复键——树状数组
数据结构·算法
H1785350909618 小时前
SolidWorks第四部分_直接实体建模特征9_替换面原理
线性代数·算法·机器学习·3d建模·solidworks
不会就选b18 小时前
算法日常・每日刷题--<二分查找>3
算法
绿算技术18 小时前
Mooncake 与绿算ForinnBase GroundPool如何联手打破推理僵局?
科技·算法·架构