代码随想录一刷记录Day44——leetcode1143.最长公共子序列 53. 最大子序和

前言

之前就有刷代码随想录,但奈何总是三天打鱼两天晒网,而且刷的也很囫囵吞枣,于是乎决定参加代码随想录训练营,准备精刷一遍,希望自己能坚持下去,结营后自己的算法水平能更上一个level,冲ing!

leetcode1143.最长公共子序列

题目链接1143.最长公共子序列

思路

本题和718. 最长重复子数组区别在于这里不要求是连续的。

  1. 确定dp数组以及下标的含义
    dpij:长度为0, i - 1的字符串text1与长度为0, j - 1的字符串text2的最长公共子序列为dpij
  2. 确定递推公式
    主要就是两大情况: 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);
  3. dp数组如何初始化
    先看看dpi0应该是多少呢?text10, i-1和空串的最长公共子序列自然是0,所以dpi0 = 0;同理dp0j也是0。
  4. 确定遍历顺序
    从前向后,从上到下来遍历这个矩阵。dptext1.size()text2.size()为最终结果

代码

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()];        
    }
};

leetcode53. 最大子序和

题目链接leetcode53. 最大子序和

思路

  1. 确定dp数组以及下标的含义
    dpi:包括下标i(以numsi为结尾)的最大连续子序列和为dpi
  2. 确定递推公式
    dpi只有两个方向可以推出来:
    dpi - 1 + numsi,即:numsi加入当前连续子序列和
    numsi,即:从头开始计算当前连续子序列和
    一定是取最大的,所以dpi = max(dpi - 1 + numsi, numsi);
  3. dp数组如何初始化
    根据dpi的定义,很明显dp0应为nums0即dp0 = nums0
  4. 确定遍历顺序
    递推公式中dpi依赖于dpi - 1的状态,需要从前向后遍历。
  5. 打印dp数组
    注意最后的结果可不是dpnums.size() - 1。要找最大的连续子序列,就应该找每一个i为终点的连续最大子序列。
    所以在递推公式的时候,可以直接选出最大的dpi

代码

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;      
    }
};

leetcode

题目链接

思路

代码

相关推荐
朔北之忘 Clancy几秒前
2026 年 3 月青少年软编等考 C/C++ 一级真题解析
c语言·开发语言·c++·青少年编程·题解·考级
MegaDataFlowers12 分钟前
101.对称二叉树
算法
小成2023032026515 分钟前
C++~01面向对象基础
开发语言·c++
Jasmine_llq31 分钟前
《B3939 [GESP样题 四级] 绝对素数》
数据结构·算法·素数判断算法·数字拆分与反转算法·区间遍历枚举·双条件判断逻辑
workflower35 分钟前
具身智能研究对象:物理交互中的智能行为
设计模式·动态规划·软件工程·软件构建·scrum
郝学胜-神的一滴1 小时前
干货版《算法导论》07:递归视角下的选择排序与归并排序
java·数据结构·c++·python·程序人生·算法·排序算法
csdn_aspnet1 小时前
javascript 算法 LeetCode 编号 70 - 爬楼梯
开发语言·javascript·算法·leetcode·ecmascript
shehuiyuelaiyuehao1 小时前
多线程入门
java·python·算法
Navigator_Z1 小时前
LeetCode //C - 1073. Adding Two Negabinary Numbers
c语言·算法·leetcode
醇氧1 小时前
【OpenClaw】更换阿里百炼完整配置指南
算法·ai