【算法刷题day52】Leetcode:300. 最长递增子序列、674. 最长连续递增序列、718. 最长重复子数组

草稿图网站
java的Deque

Leetcode 300. 最长递增子序列

题目:300. 最长递增子序列
解析:代码随想录解析

解题思路

dp数组的含义是以该元素为结尾的最大长度是多少,并使max来记录答案

代码

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

总结

暂无

Leetcode 674. 最长连续递增序列

题目:674. 最长连续递增序列
解析:代码随想录解析

解题思路

和第300题的区别是,每次只要判断与前一个的对比

代码

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

总结

暂无

Leetcode 718. 最长重复子数组

题目:718. 最长重复子数组
解析:代码随想录解析

解题思路

使用二维数组,如果nums1的第i-1个元素和第nums2的第i-2个元素如果相同,则使匹配数dp[i][j]等于dp[i-1][j-1] + 1

代码

class Solution {
    public int findLength(int[] nums1, int[] nums2) {
        int result = 0;
        int [][]dp = new int[nums1.length+1][nums2.length+1];
        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;
                result = Math.max(result, dp[i][j]);
            }
        }
        return result;
    }
}

//滚动数组
class Solution {
    public int findLength(int[] nums1, int[] nums2) {
        int result = 0;
        int []dp = new int[nums2.length+1];
        for (int i = 1; i <= nums1.length; i++) {
            for (int j = nums2.length; j > 0; j--) {
                if (nums1[i-1] == nums2[j-1])
                    dp[j] = dp[j-1] + 1;
                else
                    dp[j] = 0;
                result = Math.max(result, dp[j]);
            }
        }
        return result;
    }
}

总结

暂无

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-05-14 17:30:06       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-14 17:30:06       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-14 17:30:06       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-14 17:30:06       18 阅读

热门阅读

  1. Linux多线程http服务器技术点分析

    2024-05-14 17:30:06       9 阅读
  2. Pipenv 安装依赖包的源码

    2024-05-14 17:30:06       9 阅读
  3. 初步了解json文件

    2024-05-14 17:30:06       9 阅读
  4. html5关于WebSocket的一些特点与用例

    2024-05-14 17:30:06       11 阅读
  5. Kubernetes——命令指南

    2024-05-14 17:30:06       8 阅读
  6. C#如何通过反射获取外部dll的函数

    2024-05-14 17:30:06       11 阅读
  7. 力扣阶段练习(1).消失的数字

    2024-05-14 17:30:06       13 阅读
  8. 通过vue2来类比学习vue3

    2024-05-14 17:30:06       11 阅读
  9. Python 自动化脚本系列:第4集

    2024-05-14 17:30:06       10 阅读
  10. DOTCPP题目 2782: 整数大小比较

    2024-05-14 17:30:06       10 阅读
  11. vue2响应式和vue3响应式

    2024-05-14 17:30:06       10 阅读
  12. [Python]锁

    2024-05-14 17:30:06       11 阅读
  13. spring boot 线程池的应用

    2024-05-14 17:30:06       14 阅读