力扣爆刷第131天之动态规划五连刷(子序列问题)

2024-05-02 16:44

本文主要是介绍力扣爆刷第131天之动态规划五连刷(子序列问题),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

力扣爆刷第131天之动态规划五连刷(子序列问题)

文章目录

      • 力扣爆刷第131天之动态规划五连刷(子序列问题)
      • 一、714. 买卖股票的最佳时机含手续费
      • 二、300. 最长递增子序列
      • 三、674. 最长连续递增序列
      • 四、718. 最长重复子数组
      • 五、1143. 最长公共子序列

一、714. 买卖股票的最佳时机含手续费

题目链接:https://leetcode.cn/problems/best-time-to-buy-and-sell-stock-with-transaction-fee/description/
思路:本题对交易次数没有限制,但是每次交易都需要扣减手续费,这个没啥问题,依然是每天分为两种可能性,一种是持有,一种是不持有,持有分为之前就已经持有了,和今天才持有,不持有分为,之前就已经不持有了,和今天才不持有。至于手续费在今天买入时扣减和今天卖出时扣减都是一样的。

class Solution {public int maxProfit(int[] prices, int fee) {int[] dp = new int[2];dp[0] = -prices[0] - fee;for(int i = 1; i < prices.length; i++) {dp[0] = Math.max(dp[0], dp[1] - prices[i] - fee);dp[1] = Math.max(dp[1], dp[0] + prices[i]);}return dp[1];}
}

二、300. 最长递增子序列

题目链接:https://leetcode.cn/problems/longest-increasing-subsequence/description/
思路:求最长递增子序列,子序列不一定是连续的。其实推到状态与状态之间怎么转移非常简单。如果nums[i] < nums[j] ,那么dp[j]是不是就等于dp[i]+1了呀?还是很好想到这一点的。定义dp[i]表示在区间[0, i]中以nums[i]为结尾的最长子序列的长度。既然求的是最长的递增子序列,即使nums[i] < nums[j]了,也需要考虑是否把其加入。故 dp[i] = Math.max(dp[j] + 1, dp[i]);

class Solution {public int lengthOfLIS(int[] nums) {int max = 1;int[] dp = new int[nums.length];Arrays.fill(dp, 1);for(int i = 1; i < nums.length; i++) {for(int j = 0; j < i; j++) {if(nums[j] < nums[i]) {dp[i] = Math.max(dp[j] + 1, dp[i]);}}max = Math.max(max, dp[i]);}return max;}
}

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

题目链接:https://leetcode.cn/problems/longest-continuous-increasing-subsequence/description/
思路:上一题是非连续的,本题是连续的,非连续的需要考虑每一个符合要求的元素是否被选择,而连续的无需考虑,不符合的话就相当于一个新的子序列了。定义dp[i]表示在区间[0, i]中以nums[i]为结尾的最长连续递增子序列的长度,所以只需要nums[i] > nums[i-1],就可以得到状态的转移 dp[i] = dp[i-1] + 1。

class Solution {public int findLengthOfLCIS(int[] nums) {int[] dp = new int[nums.length];Arrays.fill(dp, 1);int max = 1;for(int i = 1; i < nums.length; i++) {if(nums[i-1] < nums[i]) {dp[i] = dp[i-1] + 1;}if(dp[i] > max) max = dp[i];}return max;}
}

四、718. 最长重复子数组

题目链接:https://leetcode.cn/problems/maximum-length-of-repeated-subarray/description/
思路:求最长重复子数组,子数组是连续的,连续的话我们只考虑相等时的状态,因为不等时根据定义就是0了。定义dp[i][j]表示在区间nums1[0, i]和区间nums2[0, j]中以nums1[i]和nums2[j]为结尾相等的最长重复子数组的长度,一切从定义出发,结尾都不相等自然是为0的,数组创建时自然是0,所以只考虑结尾相等的情况,即nums[i]1 == nums2[j],那么 dp[i][j] = dp[i-1][j-1] + 1;

class Solution {public int findLength(int[] nums1, int[] nums2) {int m = nums1.length, n = nums2.length, max = 0;int[][] dp = new int[m+1][n+1];for(int i = 0; i < m; i++) {for(int j = 0; j < n; j++) {if(nums1[i] == nums2[j]) {dp[i+1][j+1] = dp[i][j] + 1;}if(dp[i+1][j+1] > max) max = dp[i+1][j+1];}}return max;}
}

五、1143. 最长公共子序列

题目链接:https://leetcode.cn/problems/longest-common-subsequence/description/
思路:上一题求的是最长重复的子数组是连续的,本题求的是最长重复子序列这个是不连续的。对于连续的情况是不需要考虑不相等的,对于不连续的情况,想不相等都得考虑。定义dp[i][j]表示在区间text1[0, i]和区间text2[0, j]上以text1[i]和text2[j]为结尾的最长相等子序列,那么如果text1[i] == text2[j],那么dp[i][j] = dp[i-1][j-1] + 1,dp数组一定是依赖于上一个位置的状态,也就是text1[i-1]与text2[j-1]的情况。
如果text1[i] != text2[j] ,那么dp[i][j] = Math.max(dp[i][j-1], dp[i-1][j]),如果结尾不等,就从各退一步的状态里寻找最长结果。

class Solution {public int longestCommonSubsequence(String text1, String text2) {int m = text1.length(), n = text2.length();int[][] dp = new int[m+1][n+1];for(int i = 0; i < m; i++) {for(int j = 0; j < n; j++) {if(text1.charAt(i) == text2.charAt(j)) {dp[i+1][j+1] = dp[i][j] + 1;}else{dp[i+1][j+1] = Math.max(dp[i+1][j], dp[i][j+1]);}}}return dp[m][n];}
}

这篇关于力扣爆刷第131天之动态规划五连刷(子序列问题)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

numpy求解线性代数相关问题

《numpy求解线性代数相关问题》本文主要介绍了numpy求解线性代数相关问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 在numpy中有numpy.array类型和numpy.mat类型,前者是数组类型,后者是矩阵类型。数组

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

解决Cron定时任务中Pytest脚本无法发送邮件的问题

《解决Cron定时任务中Pytest脚本无法发送邮件的问题》文章探讨解决在Cron定时任务中运行Pytest脚本时邮件发送失败的问题,先优化环境变量,再检查Pytest邮件配置,接着配置文件确保SMT... 目录引言1. 环境变量优化:确保Cron任务可以正确执行解决方案:1.1. 创建一个脚本1.2. 修

Python 标准库time时间的访问和转换问题小结

《Python标准库time时间的访问和转换问题小结》time模块为Python提供了处理时间和日期的多种功能,适用于多种与时间相关的场景,包括获取当前时间、格式化时间、暂停程序执行、计算程序运行时... 目录模块介绍使用场景主要类主要函数 - time()- sleep()- localtime()- g