leetcode 1035. Uncrossed Lines

题目描述

本题本质上就是求nums1和nums2的最长公共子序列的长度。因此本题本质上与第1143题一模一样。

代码:

cpp 复制代码
class Solution {
public:
    int maxUncrossedLines(vector<int>& nums1, vector<int>& nums2) {
        //本题等价于求nums1和nums2的最长公共子序列的长度
        int len1 = nums1.size();
        int len2 = nums2.size();
        //i的取值范围是[1,len1]
        //j的取值范围是[1,len2]
        //dp[i][j]表示nums1[0,i-1]和nums2[0,j-1]的最长公共子序列的长度
        //dp[0][j]表示nums1为空,此时不存在公共子序列,dp[0][j]都应该等于0
        //dp[i][0]表示nums2为空,此时不存在公共子序列,dp[i][0]都应该等于0
        //i!=0 且 j!=0时,有两种可能:
        //如果nums1[i-1]等于nums2[j-1],dp[i][j]=dp[i-1][j-1]+1,dp[i][j]由前面的dp[i-1][j-1]覆盖,可以不初始化,或者为了编码方便可以统一初始化为0
        //如果nums1[i-1]不等于nums2[j-1],dp[i][j]=max(dp[i-1][j],dp[i][j-1]),dp[i][j]由前面的dp[i-1][j]或者dp[i][j-1]覆盖,可以不初始化,或者为了编码方便可以统一初始化为0
        vector<vector<int>> dp(len1+1,vector<int>(len2+1,0));
        for(int i = 1;i <= len1;i++){
            for(int j =1;j <= len2;j++){
                if(nums1[i-1] == nums2[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[len1][len2];
    }
};
相关推荐
MYX_30930 分钟前
第三章 线型神经网络
深度学习·神经网络·学习·算法
坚持编程的菜鸟2 小时前
LeetCode每日一题——三角形的最大周长
算法·leetcode·职场和发展
Moniane3 小时前
FastGPT 与 MCP 协议概述
算法
Meteor_cyx4 小时前
Day12 二叉树遍历
算法
加藤不太惠4 小时前
十大排序其六
算法·排序算法
前端小刘哥4 小时前
视频推拉流平台EasyDSS技术特点及多元应用场景剖析
算法
Brianna Home4 小时前
从零到一:用Godot打造2D游戏《丛林探险》
算法·游戏·性能优化·游戏引擎·bug·godot·动画
小欣加油4 小时前
leetcode 143 重排链表
数据结构·c++·算法·leetcode·链表
courniche4 小时前
ECDH、ECDHE、ECDLP、ECDSA傻傻分不清?
算法·密码学
前端小刘哥5 小时前
超低延迟与高并发:视频直播点播平台EasyDSS在游戏直播场景的技术实践
算法