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

文章目录

草稿图网站
java的Deque

Leetcode 300. 最长递增子序列

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

解题思路

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

代码

java 复制代码
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题的区别是,每次只要判断与前一个的对比

代码

java 复制代码
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

代码

java 复制代码
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;
    }
}

总结

暂无

相关推荐
拼好饭和她皆失2 分钟前
逆元,除法同余原理
算法·逆元·除法同余原理
leiming63 分钟前
c++ 利用模板创建一个可以储存任意类型数据的数组类
开发语言·c++·算法
TL滕5 分钟前
从0开始学算法——第二十天(简易搜索引擎)
笔记·学习·算法
cpp_250113 分钟前
P8723 [蓝桥杯 2020 省 AB3] 乘法表
数据结构·c++·算法·蓝桥杯·题解·洛谷
牛客企业服务18 分钟前
AI面试:如何从概念真正落地?
人工智能·面试·职场和发展
再__努力1点23 分钟前
【76】Haar特征的Adaboost级联人脸检测全解析及python实现
开发语言·图像处理·人工智能·python·算法·计算机视觉·人脸检测
溟洵23 分钟前
【算法C++】链表(题目列表:两数相加、两两交换链表中的节点、重排链表、合并 K 个升序链表、K 个一组翻转链表7)
数据结构·c++·算法·链表
_OP_CHEN24 分钟前
【C++数据结构进阶】玩转并查集:从原理到实战,C++ 实现与高频面试题全解析
数据结构·c++·算法
gugugu.24 分钟前
算法:hot100---128. 最长连续序列
算法
铭哥的编程日记28 分钟前
后端面试通关笔记:从真题到思路(me)
笔记·面试·职场和发展