代码随想录算法训练营29期Day57|LeetCode 1143,1035,53

文档讲解:最长公共子序列 不相交的线 最大子序和

1143.最长公共子序列

题目链接https://leetcode.cn/problems/longest-common-subsequence/description/

思路:

设dpij:长度为0, i - 1的字符串text1与长度为0, j - 1的字符串text2的最长公共子序列为dpij

主要就是两大情况: text1i - 1 与 text2j - 1相同,text1i - 1 与 text2j - 1不相同

如果text1i - 1 与 text2j - 1相同,那么找到了一个公共元素,所以dpij = dpi - 1j - 1 + 1;

如果text1i - 1 与 text2j - 1不相同,那就看看text10, i - 2与text20, j - 1的最长公共子序列 和 text10, i - 1与text20, j - 2的最长公共子序列,取最大的。

即:dpij = max(dpi - 1j, dpij - 1);

先看看dpi0应该是多少呢?

test10, i-1和空串的最长公共子序列自然是0,所以dpi0 = 0;

同理dp0j也是0。

核心代码:

cpp 复制代码
class Solution {
public:
    int longestCommonSubsequence(string text1, string text2) {
        vector<vector<int>> dp(text1.size() + 1, vector<int>(text2.size() + 1, 0));
        for (int i = 1; i <= text1.size(); i++) {
            for (int j = 1; j <= text2.size(); j++) {
                if (text1[i - 1] == text2[j - 1]) {
                    dp[i][j] = dp[i - 1][j - 1] + 1;
                } else {
                    dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]);
                }
            }
        }
        return dp[text1.size()][text2.size()];
    }
};

1035.不相交的线

题目链接: https://leetcode.cn/problems/uncrossed-lines/description/

思路:

本题说是求绘制的最大连线数,其实就是求两个字符串的最长公共子序列的长度!

所以照着上道题做就行了。

核心代码:

cpp 复制代码
class Solution {
public:
    int maxUncrossedLines(vector<int>& A, vector<int>& B) {
        vector<vector<int>> dp(A.size() + 1, vector<int>(B.size() + 1, 0));
        for (int i = 1; i <= A.size(); i++) {
            for (int j = 1; j <= B.size(); j++) {
                if (A[i - 1] == B[j - 1]) {
                    dp[i][j] = dp[i - 1][j - 1] + 1;
                } else {
                    dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]);
                }
            }
        }
        return dp[A.size()][B.size()];
    }
};

53.最大子序和

题目链接: https://leetcode.cn/problems/maximum-subarray/description/

思路:

dpi:包括下标i(以numsi为结尾)的最大连续子序列和为dpi

dpi只有两个方向可以推出来:

dpi - 1 + numsi,即:numsi加入当前连续子序列和

numsi,即:从头开始计算当前连续子序列和

一定是取最大的,所以dpi = max(dpi - 1 + numsi, numsi);

从递推公式可以看出来dpi是依赖于dpi - 1的状态,dp0就是递推公式的基础。

根据dpi的定义,很明显dp0应为nums0,即dp0 = nums0

我们要找最大的连续子序列,找每一个i为终点的连续最大子序列即可。

核心代码:

cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        if (nums.size() == 0) return 0;
        vector<int> dp(nums.size());
        dp[0] = nums[0];
        int result = dp[0];
        for (int i = 1; i < nums.size(); i++) {
            dp[i] = max(dp[i - 1] + nums[i], nums[i]); // 状态转移公式
            if (dp[i] > result) result = dp[i]; // result 保存dp[i]的最大值
        }
        return result;
    }
};

今日总结

这次的题学习时长1h,以前做过类似的。

快返校了,接着论文idea,头大。

相关推荐
vibecoding日记5 小时前
双非如何快速入职字节等大厂大模型?真实案例分析:推理优化和投机解码
算法·求职·大模型工程师
yszaygr21387 小时前
Verilog参数化游程编码RLE模块
算法
望易8 小时前
刚设计的大模型架构-双域耦合认知框架
算法·架构
复杂网络12 小时前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法
apocelipes1 天前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
HjhIron1 天前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩1 天前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek
触底反弹1 天前
🧠 搞懂 Token,才算真正入门大模型——从分词原理到 Embedding 语义实战
javascript·人工智能·算法
vivo互联网技术1 天前
ICLR 2026 | 基于后验采样的图像恢复方法LearnIR:人脸去阴影、去雾
人工智能·算法·aigc