欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 资讯 > 代码随想录算法训练营第一天 [300.最长递增子序列 674. 最长连续递增序列 718. 最长重复子数组]

代码随想录算法训练营第一天 [300.最长递增子序列 674. 最长连续递增序列 718. 最长重复子数组]

2026/5/26 13:45:01 来源:https://blog.csdn.net/weixin_45612015/article/details/140082846  浏览:    关键词:代码随想录算法训练营第一天 [300.最长递增子序列 674. 最长连续递增序列 718. 最长重复子数组]

代码随想录算法训练营第一天 [300.最长递增子序列 674. 最长连续递增序列 718. 最长重复子数组]


**一、300.最长递增子序列 **

链接: 代码随想录.
思路:dp[i] 以nums[i]为结尾的递增子序列最大长度,下标为i的数,需要和下标为0开始一直到下标为i-1的数去做比较
做题状态:看解析后做出来了

class Solution {
public:int lengthOfLIS(vector<int>& nums) {//dp[i] 以nums[i]为结尾的递增子序列最大长度vector<int> dp(nums.size(),1);int result = 1;for(int i = 0;i<nums.size();i++){for(int j = 0;j<i;j++){if(nums[i]>nums[j]){dp[i] = max(dp[i],dp[j]+1);}}cout << dp[i] <<' ';result = max(dp[i],result);}return result;}
};

二、674. 最长连续递增序列

链接: 代码随想录.
思路:只需要和自己的前一个数做比较就好了
做题状态:看解析后做出来了

class Solution {
public:int findLengthOfLCIS(vector<int>& nums) {vector<int> dp(nums.size(), 1);int result = 1;for (int i = 1; i < nums.size(); i++) {if(nums[i]>nums[i-1]){dp[i] = dp[i-1]+1;}cout << dp[i] <<' ';result = max(result,dp[i]);}return result;}
};

三、718. 最长重复子数组

链接: 代码随想录.
思路:二维dp数组,遍历num1和nums2
dp[i][j] 以nums1[i-1] 和nums[j-1]为下标的最长公共子序列长度为dp[i][j]

设计为i-1,初始化的时候会方便很多,dp[0][j] 和 dp[i][0]其实是没有意义的,如果第一个数相同dp[1][1] = dp[0][0]+1 并且dp[1][1] = 1,所以把dp[0][0]初始化为0
做题状态:看解析后做出来了

class Solution {
public:int findLength(vector<int>& nums1, vector<int>& nums2) {vector<vector<int>> dp(nums1.size()+1,vector<int>(nums2.size()+1,0)); //dp[i][j] 以nums1[i-1] 和nums[j-1]为下标的最长公共子序列长度为dp[i][j]int result = 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;}// cout << dp[i][j]<<" ";result = max(dp[i][j],result);}cout << endl;}return result;}
};

版权声明:

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

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

热搜词