代码随想录第52天|300.最长递增子序列 718. 最长重复子数组

2024-05-08 07:04

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

300.最长递增子序列 

300. 最长递增子序列 - 力扣(LeetCode)

代码随想录 (programmercarl.com)

动态规划之子序列问题,元素不连续!| LeetCode:300.最长递增子序列_哔哩哔哩_bilibili

给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。

子序列是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子序列。

示例 1:

  • 输入:nums = [10,9,2,5,3,7,101,18]
  • 输出:4
  • 解释:最长递增子序列是 [2,3,7,101],因此长度为 4 。

示例 2:

  • 输入:nums = [0,1,0,3,2,3]
  • 输出:4

示例 3:

  • 输入:nums = [7,7,7,7,7,7,7]
  • 输出:1

提示:

  • 1 <= nums.length <= 2500
  • -10^4 <= nums[i] <= 104

动规五部曲:

1、dp[i] 的定义:dp[i] 表示i之前包括i的以nums[i]结尾的最长递增子序列的长度;

2、状态转移方程:if(nums[i] > nums[j])  dp[i] = max(dp[i], dp[j] + 1)

3、dp数组如何初始化:dp[i] 至少包括nums[i],初始化为1;

4、确定遍历顺序:从前向后遍历;

5、举例推导dp数组:以[0,1,0,3,2]为例:

综合代码:

class Solution {public int lengthOfLIS(int[] nums) { // 定义一个名为 Solution 的类,其中有一个名为 lengthOfLIS 的公共方法,接受一个整数数组 nums 作为参数,返回一个整数int[] dp = new int[nums.length]; // 创建一个长度与 nums 相同的整数数组 dp,用于记录以每个位置 i 结尾的最长上升子序列的长度int res = 1; // 初始化结果变量为 1,因为最短的上升子序列长度至少为 1Arrays.fill(dp, 1); // 将 dp 数组初始化为 1,表示每个位置上的元素都可以作为一个长度为 1 的子序列for (int i = 1; i < dp.length; i++) { // 遍历数组 dp,从第二个位置开始for (int j = 0; j < i; j++) { // 在当前位置 i 之前的位置 j 进行遍历if (nums[i] > nums[j]) { // 如果当前位置的元素 nums[i] 大于位置 j 的元素 nums[j],说明可以将位置 i 加入到位置 j 的子序列中,形成一个更长的子序列dp[i] = Math.max(dp[i], dp[j] + 1); // 更新以位置 i 结尾的最长上升子序列的长度,取当前长度 dp[i] 与位置 j 的子序列长度加 1 中的较大值}res = Math.max(res, dp[i]); // 更新整体结果,取当前结果 res 与以位置 i 结尾的最长上升子序列长度 dp[i] 中的较大值}}return res; // 返回最终结果}
}

718. 最长重复子数组 

718. 最长重复子数组 - 力扣(LeetCode)

代码随想录 (programmercarl.com)

动态规划之子序列问题,想清楚DP数组的定义 | LeetCode:718.最长重复子数组_哔哩哔哩_bilibili

给两个整数数组 A 和 B ,返回两个数组中公共的、长度最长的子数组的长度。

示例:

输入:

  • A: [1,2,3,2,1]
  • B: [3,2,1,4,7]
  • 输出:3
  • 解释:长度最长的公共子数组是 [3, 2, 1] 。

提示:

  • 1 <= len(A), len(B) <= 1000
  • 0 <= A[i], B[i] < 100

动规五部曲:
1、确定dp数组以及下标的含义:dp[i][j]:以下标i-1结尾的A,和以下标j-1为结尾的B,最长重复子数组为dp[i][j]。该公式表明我们在遍历dp[i][j]的时候,i和j都要从1开始。

2、确定递推公式:当A[i-1]=B[i-1], dp[i][j] = dp[i-1][j-1] + 1;

3、dp数组如何初始化:根据dp[i][j] 的定义,dp[i][0] 和dp[0][j] 都是没有意义的,但是为了方便为了方便递归公式dp[i][j] = dp[i - 1][j - 1] + 1;将dp[i][0] 和dp[0][j] 初始化为0。

4、确定遍历顺序:外层for循环遍历A,内层for循环遍历B,在遍历的时候顺便把dp[i][j]的最大值记录下来。

5、举例推导dp数组:拿示例1中,A: [1,2,3,2,1],B: [3,2,1,4,7]为例:

综合代码:

// 版本一
class Solution {// 定义一个方法,参数是两个整数数组,目的是找到这两个数组中相同的元素序列的最大长度public int findLength(int[] nums1, int[] nums2) {// 初始化结果为0int result = 0;// 创建一个二维数组 dp 用于存储子问题的解,其大小为 nums1.length + 1 行,nums2.length + 1 列int[][] dp = new int[nums1.length + 1][nums2.length + 1];// 遍历 nums1 数组for (int i = 1; i < nums1.length + 1; i++) {// 遍历 nums2 数组for (int j = 1; j < nums2.length + 1; j++) {// 如果 nums1[i - 1] 与 nums2[j - 1] 相等if (nums1[i - 1] == nums2[j - 1]) {// 则更新 dp[i][j] 为 dp[i - 1][j - 1] + 1dp[i][j] = dp[i - 1][j - 1] + 1;// 更新结果为当前结果和 dp[i][j] 中的较大值result = Math.max(result, dp[i][j]);}}}// 返回最终结果return result;}
}

这篇关于代码随想录第52天|300.最长递增子序列 718. 最长重复子数组的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JavaScript对象转数组的三种方法实现

《JavaScript对象转数组的三种方法实现》本文介绍了在JavaScript中将对象转换为数组的三种实用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录方法1:使用Object.keys()和Array.map()方法2:使用Object.entr

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

Python屏幕抓取和录制的详细代码示例

《Python屏幕抓取和录制的详细代码示例》随着现代计算机性能的提高和网络速度的加快,越来越多的用户需要对他们的屏幕进行录制,:本文主要介绍Python屏幕抓取和录制的相关资料,需要的朋友可以参考... 目录一、常用 python 屏幕抓取库二、pyautogui 截屏示例三、mss 高性能截图四、Pill

使用MapStruct实现Java对象映射的示例代码

《使用MapStruct实现Java对象映射的示例代码》本文主要介绍了使用MapStruct实现Java对象映射的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、什么是 MapStruct?二、实战演练:三步集成 MapStruct第一步:添加 Mave