代码随想录算法训练营day52 | 300.最长递增子序列,674. 最长连续递增序列,718. 最长重复子数组

news/2024/11/20 15:38:48/

代码随想录算法训练营day52 | 300.最长递增子序列,674. 最长连续递增序列,718. 最长重复子数组

  • 300.最长递增子序列
    • 解法一:动态规划
  • 674. 最长连续递增序列
    • 解法一:动态规划
    • 解法二:双指针法
  • 718. 最长重复子数组
    • 解法一:动态规划
  • 总结


300.最长递增子序列

教程视频:https://www.bilibili.com/video/BV1ng411J7xP
在这里插入图片描述
在这里插入图片描述

解法一:动态规划

思路:
1、dp[i]含义:表示以nums[i]结尾的最长递增子序列的长度。
2、递推公式:dp[i]=Math.max(dp[j]+1,dp[i]);
3、dp数组初始化:全部初始化为1,dp[i]=1;
4、遍历顺序:外层 i 从前向后遍历,内层 j 正序倒序都可以。
5、打印验证。

class Solution {public int lengthOfLIS(int[] nums) {int[] dp = new int[nums.length];Arrays.fill(dp, 1);int result = 1;//因为外层for不是从dp[0]开始遍历,考虑单个元素情况下输出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]);}}result=Math.max(result,dp[i]);}return result;}
}

674. 最长连续递增序列

教程视频:https://www.bilibili.com/video/BV1bD4y1778v
在这里插入图片描述

解法一:动态规划

思路:
1、dp[i]含义:表示以nums[i]结尾的最长连续递增子序列的长度。
2、递推公式:if(nums[i-1]<nums[i]) dp[i]=dp[i-1]+1;
3、dp数组初始化:全部初始化为1,dp[i]=1;
4、遍历顺序:外层 i 正序遍历,内层 无需遍历。
5、打印验证。

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

解法二:双指针法

class Solution {public int findLengthOfLCIS(int[] nums) {if(nums.length==1)return 1;int maxLength=1;for(int left=0;left<nums.length;left++){int curLength=1;for(int right=left+1;right<nums.length;right++){if(nums[right-1]<nums[right]){curLength++;}else{break;}}maxLength=Math.max(maxLength,curLength);}return maxLength;}
}

718. 最长重复子数组

教程视频:https://www.bilibili.com/video/BV178411H7hV
在这里插入图片描述

解法一:动态规划

思路:
1、dp[i][j]含义:以下标 i - 1为 结尾的nums1,和以下标 j - 1 为结尾的nums2,最长重复子数组长度为dp[i][j]。 这里-1是为了简化初始化过程。
2、递推公式:两个数组指针始终对齐,需要同时-1if(nums2[j]==nums1[i]){ dp[i][j]=dp[i-1][j-1]+1; }
3、dp数组初始化:dp[0][j]和dp[i][0]无实际意义,为了保证递推有意义,全部初始化为0,dp[i][j]=0;
4、遍历顺序:外层 遍历nums1,内层遍历nums2。正序倒序无影响。
5、打印验证。

class Solution {public int findLength(int[] nums1, int[] nums2) {int[][] dp = new int[nums1.length+1][nums2.length+1];int maxLength=0;for(int i=1;i<=nums1.length;i++){for(int j=1;j<=nums2.length;j++){if(nums1[i-1]==nums2[j-1]){dp[i][j]=dp[i-1][j-1]+1;}maxLength=Math.max(maxLength,dp[i][j]);}}return maxLength;}
}//空间压缩
class Solution {public int findLength(int[] nums1, int[] nums2) {int[] dp = new int[nums2.length+1];int maxLength=0;for(int i=1;i<=nums1.length;i++){for(int j=nums2.length;j>=1;j--){if(nums1[i-1]==nums2[j-1]){dp[j]=dp[j-1]+1;}else {dp[j] = 0;//这里不能漏,否则上一阶段状态不能完全刷新}maxLength=Math.max(maxLength,dp[j]);}}return maxLength;}
}

总结

1、子数组相关题目要从尾部元素去定义dp数组;
2、两个不同序列比较时,递推公式需要考虑指针对齐的问题;
3、718. 最长重复子数组中dp[i][j]表示索引为i-1和j-1处的最长公共子序列,可以简化初始化状态。


http://www.ppmy.cn/news/89076.html

相关文章

Cadence+SPB16.2入门教程(下)

弹出Create Net Class对话框,如图4.21所示。输入名称DDR_DATA,点击OK关闭对话框。 建立DDR_ADDR的过程也一样,同时选中网络XM1ADDR0-XM1ADDR15,XM1CASN、XM1CKE0、XM1CSN0、XM1RASN、XM1WEN后右键Create->Net Class。其它就不重复了。 然后将上一步建立的两个电气规则D…

在树莓派上控制GPIO常用的编程语言有哪些

在树莓派上控制GPIO(General Purpose Input Output,通用输入输出接口),比较常用和简单的编程语言有: 1. Python 这是树莓派官方推荐语言&#xff0c;控制GPIO只需要导入RPi.GPIO库,简单易学,代码如下: import RPi.GPIO as GPIOGPIO.setmode(GPIO.BCM) GPIO.setup(18, GPIO.…

Stimulsoft报表开发工具支持电子签名啦!一起来看

Stimulsoft Reports 是一款报告编写器&#xff0c;主要用于在桌面和Web上从头开始创建任何复杂的报告。可以在大多数平台上轻松实现部署&#xff0c;如ASP.NET, WinForms, .NET Core, JavaScript, WPF, Angular, Blazor, PHP, Java等&#xff0c;在你的应用程序中嵌入报告设计器…

很后悔,才发现这个API管理神器

想必大家都注意到了&#xff0c;近半年国产API管理工具火了起来。这说明两个问题&#xff0c;第一&#xff0c;API管理的重要性被越来越多的开发者认识到了&#xff0c;研发团队对API管理的需求也越来越强了。第二&#xff0c;说明国产软件真是越来越厉害了&#xff0c;大家确实…

STM32与ESP32下载器设计

文章目录 背景STM32下载器使用现成的DAPlink选择自制DAPlink ESP32/ESP8266下载器连接接口STM32接口ESP32接口 背景 我们常用的单片机主要有STM32和ESP32&#xff0c;其中STM32下载要求SWD下载接口&#xff0c;ESP32下载要求串口&#xff0c;但需要控制ESP32 IO0和EN口高低电平…

基于Android studio二手车交易系统app

客户端&#xff1a; 用户注册&#xff1a;通过输入用户名&#xff0c;密码&#xff0c;所在地&#xff0c;联系地址以及电话和电子邮件等信息进行用户信息的注册。 二手车查看&#xff1a;用户注册登录系统后&#xff0c;可以查看二手车的基本信息&#xff0c;通过二手车的品牌…

如何避免Salesforce Apex代码中5个常见错误,提升开发技巧?

编码是一门需要严谨和谨慎的技术&#xff0c;即使是有经验的开发人员也会犯错。一些最常见的编程错误&#xff0c;可能会导致严重的后果。因此&#xff0c;作为一名开发人员&#xff0c;了解并避免这些错误是非常重要的。 本篇文章将为学习者介绍在编写Apex代码时一定要规避的…

JUnit与Mockito测试框架使用指南

JUnit与Mockito测试框架使用指南 一、简介1. JUnit概述2. JUnit的作用3. JUnit的使用方法 二、JUnit使用指南1. 单元测试的基本概念2. 常用的JUnit注解3. JUnit断言&#xff08;Assertion&#xff09;的使用方法4. JUnit的测试套件&#xff08;Suite&#xff09;使用方法5. JUn…