• 代码随想录训练营day52


    题目一:最长上升子序列

    力扣题目链接

    题目描述:

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

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

    思路分析:代码随想录

     动归五部曲:

    1. dp[i]的定义:dp[i]表示i之前包括i的以nums[i]结尾最长上升子序列的长度
    2. 状态转移方程:位置i的最长升序子序列等于j从0到i-1各个位置的最长升序子序列 + 1 的最大值。所以:if (nums[i] > nums[j]) dp[i] = max(dp[i], dp[j] + 1);
    3. dp[i]的初始化:每一个i,对应的dp[i](即最长上升子序列)起始大小至少都是1.
    4. 确定遍历顺序:dp[i] 是有0到i-1各个位置的最长升序子序列 推导而来,那么遍历i一定是从前向后遍历。
    5. 举例推导dp数组

    解法:          

    1. class Solution {
    2. public int lengthOfLIS(int[] nums) {
    3. int[] dp = new int[nums.length];
    4. Arrays.fill(dp, 1);
    5. for (int i = 0; i < dp.length; i++) {
    6. for (int j = 0; j < i; j++) {
    7. if (nums[i] > nums[j]) {
    8. dp[i] = Math.max(dp[i], dp[j] + 1);
    9. }
    10. }
    11. }
    12. int res = 0;
    13. for (int i = 0; i < dp.length; i++) {
    14. res = Math.max(res, dp[i]);
    15. }
    16. return res;
    17. }
    18. }

    题目二:最长连续递增序列

    力扣题目链接

    题目描述:

    给定一个未经排序的整数数组,找到最长且 连续递增的子序列,并返回该序列的长度。

    连续递增的子序列 可以由两个下标 l 和 rl < r)确定,如果对于每个 l <= i < r,都有 nums[i] < nums[i + 1] ,那么子序列 [nums[l], nums[l + 1], ..., nums[r - 1], nums[r]] 就是连续递增子序列。

    思路分析:代码随想录

    1. 确定dp数组(dp table)以及下标的含义:dp[i]:以下标i为结尾的数组的连续递增的子序列长度为dp[i]
    2. 确定递推公式:如果 nums[i + 1] > nums[i],那么以 i+1 为结尾的数组的连续递增的子序列长度 一定等于 以i为结尾的数组的连续递增的子序列长度 + 1 。即:dp[i + 1] = dp[i] + 1;
    3. dp数组如何初始化:dp[i]应该初始1
    4. 确定遍历顺序:从递推公式上可以看出,dp[i + 1]依赖dp[i],所以一定是从前向后遍历。
    5. 举例推导dp数组

    解法: 

    1. class Solution {
    2. public static int findLengthOfLCIS(int[] nums) {
    3. int[] dp = new int[nums.length];
    4. for (int i = 0; i < dp.length; i++) {
    5. dp[i] = 1;
    6. }
    7. int res = 1;
    8. for (int i = 0; i < nums.length - 1; i++) {
    9. if (nums[i + 1] > nums[i]) {
    10. dp[i + 1] = dp[i] + 1;
    11. }
    12. res = res > dp[i + 1] ? res : dp[i + 1];
    13. }
    14. return res;
    15. }
    16. }

    题目三:最长重复子数组

    力扣题目链接

    题目描述:给两个整数数组 nums1 和 nums2 ,返回 两个数组中 公共的 、长度最长的子数组的长度 

    思路分析:代码随想录

    解法: 

    1. class Solution {
    2. public int findLength(int[] nums1, int[] nums2) {
    3. int result = 0;
    4. int[][] dp = new int[nums1.length + 1][nums2.length + 1];
    5. for (int i = 1; i < nums1.length + 1; i++) {
    6. for (int j = 1; j < nums2.length + 1; j++) {
    7. if (nums1[i - 1] == nums2[j - 1]) {
    8. dp[i][j] = dp[i - 1][j - 1] + 1;
    9. result = Math.max(result, dp[i][j]);
    10. }
    11. }
    12. }
    13. return result;
    14. }
    15. }

  • 相关阅读:
    Linux 系统监控与性能调优
    ZOOM 2023校招笔试第二题
    面向对象的三大特性、方法重写、super关键字以及装箱拆箱(JAVA基础四)
    Ubuntu下载工具ip addr、ifconfig、ping、make
    从零开始搭建Vue3+Vite+TS+Router+Pinia脚手架
    重新整理汇编—————汇编的基础理论前置篇
    为什么 Go 语言 struct 要使用 tags
    JavaSE学习文档(下)
    Linux内存管理知识总结(一)
    [附源码]Python计算机毕业设计SSM教师信息采集系统(程序+LW)
  • 原文地址:https://blog.csdn.net/weixin_45977348/article/details/127809524