动态规划算法-子序列问题(数组中不连续的一段):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;
    }
}
相关推荐
八解毒剂1 分钟前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
程序员黑豆8 分钟前
AI全栈开发 - Java:变量
java·前端·ai编程
我是一颗柠檬9 分钟前
【Java项目技术亮点】分库分表+数据路由策略:单表5000万后的架构升级方案
java·开发语言·分布式·架构
布朗克16817 分钟前
25 IO流高级操作——序列化、NIO与Files工具类
java·数据库·io·nio
小研说技术22 分钟前
Spring AI实现rag流程(简易版)
java·后端
运行时记录24 分钟前
别再手动写提示词了 — SkillOpt 让技能文档自己进化
算法
亓才孓27 分钟前
【本地项目引用外部库的类,想修改字段遇到的请缓存的问题】
java·maven
啦啦啦啦啦zzzz37 分钟前
算法总结(二分查找、双指针)
c++·算法
小林敲代码778837 分钟前
记录一下IDEA中很多变量变色的方案
java·开发语言·spring boot·idea
南知意-41 分钟前
IDEA 2026.1最新版安装教程
java·ide·intellij-idea·idea安装·idea激活