LeetCode 第51天 | 300. 最长递增子序列 674. 最长连续递增序列 718. 最长重复子数组 动态规划

本文主要是介绍LeetCode 第51天 | 300. 最长递增子序列 674. 最长连续递增序列 718. 最长重复子数组 动态规划,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

300. 最长递增子序列
用当前值与之前的左右值比较,如果大于前面的值,那么就可以用前面的dp加上长度一(当前值本身长度)。就是前面的值大小记录下来,后面会用的到,到dp[i]的点记录了dp[i]之前的局部最长子序列,那么如果后续遍历到的值严格大于该值的话,就可以动态更新后面的值了。解决局部问题记录状态,解决全局问题就可以利用局部解的值来优化全局解。

class Solution {
public:int lengthOfLIS(vector<int>& nums) {// dp[i]表示到i的最长递增子序列if (nums.size() == 0) return 0;vector<int> dp(nums.size(), 1);int res = 1;for (int i = 1; i < nums.size();i++) {for (int j = 0; j < i; j++) {if (nums[i] > nums[j]) {dp[i] = max(dp[i], dp[j]+1);}}if (dp[i] > res) res = dp[i];}return res;}
};

674. 最长连续递增序列
这个序列要求是连续的,相当于子串。
在一个循环遍历中如果nums[i] > nums[i-1],那么就证明该值和前面一个还是递增的,而前面一个连续多少个,这已经在前面计算过了。至于更前面相隔不连续的序列,就不用了考虑了。同时利用res记录当前的最大值,即为最终结果。

class Solution {
public:int findLengthOfLCIS(vector<int>& nums) {int n = nums.size();if (n == 0) return 0;int res = 1;vector<int> dp(n, 1);for (int i = 1; i < n; i++) {if (nums[i] > nums[i-1])dp[i] = dp[i-1] + 1;if (dp[i] > res) res = dp[i];}for (auto i : dp) cout<<i<<" ";return res;}
};

718. 最长重复子数组
找两个数组的重复子数组,子数组的连续的,相当于子串。这题其实我还没搞透彻,这是跟着代码随想录敲的代码。下次一定搞懂(嘻嘻)

class Solution {
public:int findLength(vector<int>& nums1, vector<int>& nums2) {vector<vector<int>> dp(nums1.size() + 1, vector<int>(nums2.size() + 1, 0));int res = 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;}if (dp[i][j] > res) res = dp[i][j];}}return res;}
};

今天已经写了十题左右的LeetCode了,一般是自己写,一半是照抄的,当然照抄并不可耻,熟能生巧,起码也熟练度上有进步的。今天最难的题是含有冻结期的股票交易,状态难想,代码不规整,挺难实现的,但是得明确一个原则就是股票求的是最佳受益,dp[i]表示第i天的受益,至于第二维的状态定义完全取决于自己。子序列是最清新的题,就是再用一个空间来存储到达这里的最长递增序列,之后遍历时就可以利用前面局部已经得到的结果。加油,一天有一天的收获。

这篇关于LeetCode 第51天 | 300. 最长递增子序列 674. 最长连续递增序列 718. 最长重复子数组 动态规划的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/784685

相关文章

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

springboot如何通过http动态操作xxl-job任务

《springboot如何通过http动态操作xxl-job任务》:本文主要介绍springboot如何通过http动态操作xxl-job任务的问题,具有很好的参考价值,希望对大家有所帮助,如有错... 目录springboot通过http动态操作xxl-job任务一、maven依赖二、配置文件三、xxl-

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

Java调用C#动态库的三种方法详解

《Java调用C#动态库的三种方法详解》在这个多语言编程的时代,Java和C#就像两位才华横溢的舞者,各自在不同的舞台上展现着独特的魅力,然而,当它们携手合作时,又会碰撞出怎样绚丽的火花呢?今天,我们... 目录方法1:C++/CLI搭建桥梁——Java ↔ C# 的“翻译官”步骤1:创建C#类库(.NET

MyBatis编写嵌套子查询的动态SQL实践详解

《MyBatis编写嵌套子查询的动态SQL实践详解》在Java生态中,MyBatis作为一款优秀的ORM框架,广泛应用于数据库操作,本文将深入探讨如何在MyBatis中编写嵌套子查询的动态SQL,并结... 目录一、Myhttp://www.chinasem.cnBATis动态SQL的核心优势1. 灵活性与可

Mybatis嵌套子查询动态SQL编写实践

《Mybatis嵌套子查询动态SQL编写实践》:本文主要介绍Mybatis嵌套子查询动态SQL编写方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、实体类1、主类2、子类二、Mapper三、XML四、详解总结前言MyBATis的xml文件编写动态SQL

利用Python实现时间序列动量策略

《利用Python实现时间序列动量策略》时间序列动量策略作为量化交易领域中最为持久且被深入研究的策略类型之一,其核心理念相对简明:对于显示上升趋势的资产建立多头头寸,对于呈现下降趋势的资产建立空头头寸... 目录引言传统策略面临的风险管理挑战波动率调整机制:实现风险标准化策略实施的技术细节波动率调整的战略价

SpringBoot实现Kafka动态反序列化的完整代码

《SpringBoot实现Kafka动态反序列化的完整代码》在分布式系统中,Kafka作为高吞吐量的消息队列,常常需要处理来自不同主题(Topic)的异构数据,不同的业务场景可能要求对同一消费者组内的... 目录引言一、问题背景1.1 动态反序列化的需求1.2 常见问题二、动态反序列化的核心方案2.1 ht

golang实现动态路由的项目实践

《golang实现动态路由的项目实践》本文主要介绍了golang实现动态路由项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习... 目录一、动态路由1.结构体(数据库的定义)2.预加载preload3.添加关联的方法一、动态路由1