动态规划算法-子序列问题(数组中不连续的一段):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;
    }
}
相关推荐
海清河晏11137 分钟前
数据结构 | 单循环链表
数据结构·算法·链表
wuweijianlove5 小时前
算法性能的渐近与非渐近行为对比的技术4
算法
一定要AK5 小时前
Spring 入门核心笔记
java·笔记·spring
A__tao5 小时前
Elasticsearch Mapping 一键生成 Java 实体类(支持嵌套 + 自动过滤注释)
java·python·elasticsearch
_dindong5 小时前
cf1091div2 C.Grid Covering(数论)
c++·算法
AI成长日志5 小时前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
KevinCyao5 小时前
java视频短信接口怎么调用?SpringBoot集成视频短信及回调处理Demo
java·spring boot·音视频
迷藏4945 小时前
**发散创新:基于Rust实现的开源合规权限管理框架设计与实践**在现代软件架构中,**权限控制(RBAC)** 已成为保障
java·开发语言·python·rust·开源
黎阳之光5 小时前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
skywalker_115 小时前
力扣hot100-3(最长连续序列),4(移动零)
数据结构·算法·leetcode