day-53 代码随想录算法训练营(19)动态规划 part 14

1143.最长公共子序列(坐牢)

cpp 复制代码
class Solution {
public:
    int longestCommonSubsequence(string text1, string text2) {
        int n=text1.size(),m=text2.size();
        vector<vector<int>>dp(n+1,vector<int>(m+1,0));
        for(int i=1;i<=n;i++){
            for(int j=1;j<=m;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]);
                //从 0~i-2 和 0~j-1 中,0~i-1 和 0~j-2中,找最长公共子序列
            }
        }
        return dp[n][m];
    }
};

1035.不相交的线

思路:啊听说跟上一题一摸一样
cpp 复制代码
class Solution {
public:
    int maxUncrossedLines(vector<int>& nums1, vector<int>& nums2) {
        int n=nums1.size(),m=nums2.size();
        vector<vector<int>>dp(n+1,vector<int>(m+1,0));
        for(int i=1;i<=n;i++){
            for(int j=1;j<=m;j++){
                if(nums1[i-1]==nums2[j-1]) dp[i][j]=dp[i-1][j-1]+1;
                else
                    dp[i][j]=max(dp[i][j-1],dp[i-1][j]);
            }
        }
        return dp[n][m];
    }
};

53.最大子序和

思路一:直接进行累加(贪心)
  • 当和超过最大值时进行更新
  • 当和小于等于0时把和置空
cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
       int res=INT_MIN,sum=0;
       for(int i=0;i<nums.size();i++){
           sum+=nums[i];
           if(sum>res) res=sum;
           if(sum<=0) sum=0;
       }
       return res;
    }
};
思路二:动态规划
  • 1.dp存储:以nums[i]结尾的最大子数组和为dp[i]
  • 2.动态转移方程:dp[i]=max(nums[i]+dp[i-1],nums[i])
  • 3.初始化:dp[0]=nums[0]
  • 4.遍历顺序:1~n
cpp 复制代码
class Solution {
public:
    int maxSubArray(vector<int>& nums) {
       int n=nums.size();
       vector<int>dp(n,0);
       dp[0]=nums[0];
       int res=dp[0];
       for(int i=1;i<n;i++){
           dp[i]=max(dp[i-1]+nums[i],nums[i]);//最大值在上一位+当前位 和 当前位之间
           if(dp[i]>res) res=dp[i];//更新最大值
       }
       return res;
    }
};
相关推荐
搞笑症患者14 分钟前
压缩感知(Compressed Sensing, CS)
算法·最小二乘法·压缩感知·正交匹配追踪omp·迭代阈值it算法
im_AMBER17 分钟前
Leetcode 101 对链表进行插入排序
数据结构·笔记·学习·算法·leetcode·排序算法
快手技术35 分钟前
AAAI 2026|全面发力!快手斩获 3 篇 Oral,12 篇论文入选!
前端·后端·算法
颜酱37 分钟前
前端算法必备:滑动窗口从入门到很熟练(最长/最短/计数三大类型)
前端·后端·算法
做科研的周师兄39 分钟前
【MATLAB 实战】栅格数据 K-Means 聚类(分块处理版)—— 解决大数据内存溢出、运行卡顿问题
人工智能·算法·机器学习·matlab·kmeans·聚类
X在敲AI代码39 分钟前
leetcodeD3
数据结构·算法
码农小韩1 小时前
基于Linux的C++学习——循环
linux·c语言·开发语言·c++·算法
CoderCodingNo1 小时前
【GESP】C++五级/四级练习(双指针/数学) luogu-P1147 连续自然数和
开发语言·c++·算法
颜酱1 小时前
前端算法必备:双指针从入门到很熟练(快慢指针+相向指针+滑动窗口)
前端·后端·算法
Wect1 小时前
LeetCode 274. H 指数:两种高效解法全解析
算法·typescript