• 代码随想录算法训练营day53||1035.不相交的线||53. 最大子序和


    1035.不相交的线

    思路:

    直线不能相交,就说明在字符串A中找到一个与字符串B相同的子序列,而且这个子序列不能改变相对顺序,只要相对顺序不改变,链接相同数字的直线就不会相交。

    1. class Solution {
    2. public:
    3. int maxUncrossedLines(vector<int>& A, vector<int>& B) {
    4. vectorint>> dp(A.size() + 1, vector<int>(B.size() + 1, 0));
    5. for (int i = 1; i <= A.size(); i++) {
    6. for (int j = 1; j <= B.size(); j++) {
    7. if (A[i - 1] == B[j - 1]) {
    8. dp[i][j] = dp[i - 1][j - 1] + 1;
    9. } else {
    10. dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]);
    11. }
    12. }
    13. }
    14. return dp[A.size()][B.size()];
    15. }
    16. };

    53. 最大子序和

    思路:

    动规五部曲如下:

    1. 确定dp数组(dp table)以及下标的含义

    dp[i]:包括下标i之前的最大连续子序列和为dp[i]

    1. 确定递推公式

    dp[i]只有两个方向可以推出来:

    • dp[i - 1] + nums[i],即:nums[i]加入当前连续子序列和
    • nums[i],即:从头开始计算当前连续子序列和

    一定是取最大的,所以dp[i] = max(dp[i - 1] + nums[i], nums[i]);

    1. dp数组如何初始化

    从递推公式可以看出来dp[i]是依赖于dp[i - 1]的状态,dp[0]就是递推公式的基础。

    dp[0]应该是多少呢?

    根据dp[i]的定义,很明显dp[0]应为nums[0]即dp[0] = nums[0]。

    1. 确定遍历顺序

    递推公式中dp[i]依赖于dp[i - 1]的状态,需要从前向后遍历。

    1. class Solution {
    2. public:
    3. int maxSubArray(vector<int>& nums) {
    4. if (nums.size() == 0) return 0;
    5. vector<int> dp(nums.size());
    6. dp[0] = nums[0];
    7. int result = dp[0];
    8. for (int i = 1; i < nums.size(); i++) {
    9. dp[i] = max(dp[i - 1] + nums[i], nums[i]); // 状态转移公式
    10. if (dp[i] > result) result = dp[i]; // result 保存dp[i]的最大值
    11. }
    12. return result;
    13. }
    14. };

  • 相关阅读:
    浅谈欧拉角,四元数
    【CC3200AI 实验教程 1】疯壳·AI语音人脸识别(会议记录仪/人脸打卡机)-开发环境搭建
    源码安装Apache
    Java_Servlet 知识点
    东南亚三国(新/马/菲)2022女装市场趋势解读及爆品指南
    kafka 调优
    Vue中对于指令的介绍
    【WebGIS实例】(11)Cesium自定义区域裁剪(挖除&挖出)
    线性代数_第二章,矩阵
    面向对象视角下,理解Docker 镜像容器和仓库
  • 原文地址:https://blog.csdn.net/weixin_64200950/article/details/127818464