leetcode 1035. 不相交的线

2023.8.25

本题可以转化为:求两数组的最长公共子序列。 进而可以用dp算法解决。 方法类似于这题最长公共子序列 。 代码如下:

cpp 复制代码
class Solution {
public:
    int maxUncrossedLines(vector<int>& nums1, vector<int>& nums2) {
        vector<vector<int>> dp(nums1.size()+1,vector<int>(nums2.size()+1,0));
        for(int i=1; i<=nums1.size(); i++)
        {
            for(int j=1; j<=nums2.size(); 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[nums1.size()][nums2.size()];
    }
};
相关推荐
tobias.b几秒前
408真题解析-2009-10-数据结构-排序
数据结构·算法·排序算法·408考研·408真题·真题解析
Zachary_zlc4 分钟前
有向无环图检测算法和关键路径算法
算法
你撅嘴真丑6 分钟前
素数回文数的个数 与 求分数序列和
算法
好奇龙猫8 分钟前
【大学院-筆記試験練習:线性代数和数据结构(2)】
数据结构·线性代数·决策树
Wuliwuliii13 分钟前
贡献延迟计算DP
数据结构·c++·算法·动态规划·dp
D_FW14 分钟前
数据结构第一章:绪论
数据结构·考研
ysn1111117 分钟前
简单多边形三角剖分---耳切法(含源码)
算法
e疗AI产品之路18 分钟前
一文介绍Philips DXL心电图算法
算法·pan-tompkins·心电分析
YGGP24 分钟前
【Golang】LeetCode 21. 合并两个有序链表
leetcode·链表·golang
小袁顶风作案28 分钟前
leetcode力扣——135.分发糖果
算法·leetcode·职场和发展