动态规划算法-子序列问题(数组中不连续的一段):30.最长数对链

题目链接:646. 最长数对链(中等)

算法原理:

解法:动态规划

Java代码:

java 复制代码
import java.util.Arrays;

/**
 * Created with IntelliJ IDEA.
 * Description:
 * User: 王洋
 * Date: 2025-10-23
 * Time: 19:39
 */
class Solution {
    //646. 最长数对链
    //看完算法原理后照着笔记自己写的,就是预处理部分看了一下吴小哲的
    //一开始以为用的是Pair的数据结构呢
    //吴小哲跟我写的一样
    public int findLongestChain(int[][] pairs) {
        //预处理:按照第一个数字来排序,这里的pairs是数组,不是Pair
        //Pair属于数据结构,是数对(键值对)
        Arrays.sort(pairs,(a, b)->a[0]-b[0]);
        int n=pairs.length;
        int[] dp=new int[n];
        Arrays.fill(dp,1);
        for(int i=1;i<n;i++){
            for(int j=0;j<i;j++){
                if(pairs[j][1]<pairs[i][0])
                    dp[i]=Math.max(dp[i],dp[j]+1);
            }
        }
        int ret=1;
        for(int x:dp) ret=Math.max(ret,x);
        return ret;
    }
}
相关推荐
小园子的小菜2 分钟前
Spring事务失效9大场景(Java面试高频)
java·spring·面试
BHXDML4 分钟前
第三章:聚类算法
算法·机器学习·聚类
向前V9 分钟前
Flutter for OpenHarmony数独游戏App实战:胜利弹窗
java·flutter·游戏
仙俊红13 分钟前
二分查找边界模板:第一个 > target / 第一个 < target(找不到就返回边界)
算法
苦藤新鸡15 分钟前
16.求数组除了当前元素的所有乘积
算法·leetcode·动态规划
Benny_Tang16 分钟前
题解:P14841 [THUPC 2026 初赛] 哈姆星与古地球学术行为影响星球文明的考古学分析
c++·算法
WilliamHu.16 分钟前
A2A协议
java·数据结构·算法
JAVA+C语言16 分钟前
如何在Java中实现线程间的通信?
java·大数据·python
这儿有个昵称17 分钟前
Java面试场景:从音视频到微服务的技术深挖
java·spring boot·spring cloud·微服务·面试·kafka·音视频
modelmd18 分钟前
Go、Java 的值类型和引用类型对比
java·golang