leetcode-646:最长数对链

简介: leetcode-646:最长数对链

题目

题目连接

给出 n 个数对。 在每一个数对中,第一个数字总是比第二个数字小。

现在,我们定义一种跟随关系,当且仅当 b < c 时,数对(c, d) 才可以跟在 (a, b) 后面。我们用这种形式来构造一个数对链。

给定一个数对集合,找出能够形成的最长数对链的长度。你不需要用到所有的数对,你可以以任何顺序选择其中的一些数对来构造。

示例:

输入:[[1,2], [2,3], [3,4]]
输出:2
解释:最长的数对链是 [1,2] -> [3,4]

解题

方法一:排序+贪心

写法一:按照第一个数排序

按照第一个数字进行排序

如果满足条件,那么res++,更新pre

如果不满足条件,那么pre要取第二个数最小的,这样更好满足后面的pair (贪心)

class Solution {
public:
    int findLongestChain(vector<vector<int>>& pairs) {
        int res=1;
        sort(pairs.begin(),pairs.end(),[](vector<int>& a,vector<int>&b){
            return a[0]<b[0];
        });
        int pre=pairs[0][1];
        for(int i=1;i<pairs.size();i++){
            if(pairs[i][0]>pre){
                res++;
                pre=pairs[i][1];
            }else{
                pre=min(pre,pairs[i][1]);//贪心:选第二个数比较小的
            }
        }
        return res;
    }
};

写法二:按照第二个数进行排序

class Solution {
public:
    int findLongestChain(vector<vector<int>>& pairs) {
        int res=1;
        sort(pairs.begin(),pairs.end(),[](vector<int>& a,vector<int>&b){
            return a[1]<b[1];
        });
        int pre=pairs[0][1];
        for(int i=1;i<pairs.size();i++){
            if(pairs[i][0]>pre){
                res++;
                pre=pairs[i][1];
            }
        }
        return res;
    }
};
相关文章
|
8月前
|
算法 测试技术 C#
【反悔贪心】【优先队列】3049. 标记所有下标的最早秒数 II
【反悔贪心】【优先队列】3049. 标记所有下标的最早秒数 II
【动态规划刷题 14】最长递增子序列的个数&& 最长数对链
【动态规划刷题 14】最长递增子序列的个数&& 最长数对链
算法修炼Day52|● 300.最长递增子序列 ● 674. 最长连续递增序列 ● 718. 最长重复子数组
算法修炼Day52|● 300.最长递增子序列 ● 674. 最长连续递增序列 ● 718. 最长重复子数组
|
5月前
|
C语言
【Amazon 面试题1】一个数组,里面得数出现的次数是偶数次,只有一个数出现的次数是奇数次,找出那个出现奇数次的数
本文介绍了解决Amazon面试题的一种方法,即在一个所有数字出现次数都是偶数,除了一个数字出现奇数次的数组中,利用异或运算的性质找出出现奇数次的数字,并提供了C语言实现的代码示例。
76 1
|
8月前
leetcode代码记录(最长连续递增序列
leetcode代码记录(最长连续递增序列
47 2
|
8月前
leetcode代码记录(最长递增子序列
leetcode代码记录(最长递增子序列
35 1
|
8月前
|
索引
leetcode代码记录(最长重复子数组
leetcode代码记录(最长重复子数组
57 0
|
8月前
代码随想录 Day44 动规12 LeetCode T300 最长递增子序列 T674 最长连续递增序列 T718 最长重复子数组
代码随想录 Day44 动规12 LeetCode T300 最长递增子序列 T674 最长连续递增序列 T718 最长重复子数组
69 0
|
8月前
|
算法 测试技术 C#
LeetCode2444: 统计定界子数组的数目
LeetCode2444: 统计定界子数组的数目
|
8月前
leetcode-1438:绝对差不超过限制的最长连续子数组
leetcode-1438:绝对差不超过限制的最长连续子数组
52 0