当前位置: 首页> 教育> 培训 > 学校官网主页网页设计_安徽建筑人才网_保定关键词排名推广_自己建网站要多少钱

学校官网主页网页设计_安徽建筑人才网_保定关键词排名推广_自己建网站要多少钱

时间:2025/7/18 23:42:32来源:https://blog.csdn.net/weixin_41554427/article/details/147373462 浏览次数:0次
学校官网主页网页设计_安徽建筑人才网_保定关键词排名推广_自己建网站要多少钱

题目描述

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

代码:

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]覆盖,可以不初始化,或者为了编码方便可以统一初始化为0vector<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;elsedp[i][j] = max(dp[i-1][j],dp[i][j-1]);}}return dp[len1][len2];}
};
关键字:学校官网主页网页设计_安徽建筑人才网_保定关键词排名推广_自己建网站要多少钱

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: