动态规划算法-子序列问题(数组中不连续的一段):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;
    }
}
相关推荐
元亓亓亓4 分钟前
LeetCode热题100--416. 分割等和子集--中等
算法·leetcode·职场和发展
BanyeBirth5 分钟前
C++差分数组(二维)
开发语言·c++·算法
CC.GG1 小时前
【C++】STL容器----unordered_map和unordered_set的使用
java·数据库·c++
Overt0p1 小时前
抽奖系统(4)
java·spring boot·tomcat
xu_yule2 小时前
算法基础(数论)—算法基本定理
c++·算法·算数基本定理
CoderCodingNo2 小时前
【GESP】C++五级真题(结构体排序考点) luogu-B3968 [GESP202403 五级] 成绩排序
开发语言·c++·算法
想做后端的小C3 小时前
Java:接口回调
java·开发语言·接口回调
爱学习的小可爱卢3 小时前
JavaEE进阶——Spring核心设计模式深度剖析
java·spring·设计模式
毕设源码-钟学长3 小时前
【开题答辩全过程】以 个性化电影推荐网站的设计与实现为例,包含答辩的问题和答案
java·spring boot