Java教程

java 力扣 646.最长数对链

本文主要是介绍java 力扣 646.最长数对链,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

1.题目

2.解法

①一维数组+排序、动态规划

class Solution {
    public int findLongestChain(int[][] pairs) {
        int n = pairs.length;
        int[] dp = new int[n];
        Arrays.fill(dp, 1);
        Arrays.sort(pairs, (a, b) -> (a[0] - b[0]));

        for(int i = 1; i < n; i++){
            for(int j = 0; j < i; j++){
                if(pairs[i][0] > pairs[j][1]) dp[i] = Math.max(dp[i], dp[j] + 1);
            }
        }
        return dp[n - 1];
    }
}

 

这篇关于java 力扣 646.最长数对链的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!