646. Maximum Length of Pair Chain思路解析
来源:互联网 发布:淘宝运营管理制度 编辑:程序博客网 时间:2024/06/03 23:39
题目
You are given n pairs of numbers. In every pair, the first number is always smaller than the second number.
Now, we define a pair (c, d) can follow another pair (a, b) if and only if b < c. Chain of pairs can be formed in this fashion.
Given a set of pairs, find the length longest chain which can be formed. You needn’t use up all the given pairs. You can select pairs in any order.
Example 1:
Input: [[1,2], [2,3], [3,4]]
Output: 2
Explanation: The longest chain is [1,2] -> [3,4]
Note:
The number of given pairs will be in the range [1, 1000].
思路解析
要想尽量多地拼接pair,那么就应该在每次迭代的当前sub chain中末尾的pair的第二个元素值尽可能小,所以先对 Input中的pairs 按照 第二元素 升序排列,然后再遍历一次挨个判断能否连接成链条,最后链条的pair数量就是最终结果
Python实现
class Solution(object): def findLongestChain(self, pairs): """ :type pairs: List[List[int]] :rtype: int :Runtime: 112 ms """ pairs.sort(key=operator.itemgetter(1,0)) max = -float("inf") sum = 0 for i in pairs: if i[0] > max: sum += 1 max = i[1] return sum
C++实现
// Runtime: 76 msclass Solution {private: static bool compare(vector<int> a, vector<int> b) { if (a[1] == b[1]) return a[0] < b[0]; return a[1] < b[1]; }; public: int findLongestChain(vector<vector<int>>& pairs) { std::sort(pairs.begin(), pairs.end(), compare); int max = INT_MIN, sum = 0; for (int i = 0; i < pairs.size(); ++i) { if (pairs[i][0] > max) { sum += 1; max = pairs[i][1]; } } return sum; }};
时间复杂度
不管是直接使用语言内置的sort函数还是自己实现的排序函数,都是nlogn,没有最坏情况的时间复杂度小于nlogn的算法。
阅读全文
0 0
- 646. Maximum Length of Pair Chain思路解析
- 646. Maximum Length of Pair Chain
- 646. Maximum Length of Pair Chain
- [leetcode]646. Maximum Length of Pair Chain
- leetcode 646. Maximum Length of Pair Chain
- 646. Maximum Length of Pair Chain
- LeetCode 646. Maximum Length of Pair Chain
- [Leetcode] 646. Maximum Length of Pair Chain
- 646. Maximum Length of Pair Chain
- 646. Maximum Length of Pair Chain
- leetcode 646. Maximum Length of Pair Chain
- 646. Maximum Length of Pair Chain
- [leetcode] 646. Maximum Length of Pair Chain
- 646. Maximum Length of Pair Chain
- 646. Maximum Length of Pair Chain(M)
- [LeetCode] 646. Maximum Length of Pair Chain
- [LeetCode] 646. Maximum Length of Pair Chain
- 646. Maximum Length of Pair Chain
- Linux(CentOS 6.5) 安装redis
- Person中有name和age属性,要求存储若干个Person对象到磁盘中, 使用 RandomAccessFile流来实现
- JavaScript基础
- BZOJ 2698: 染色 期望
- image和TFRecord互相转换
- 646. Maximum Length of Pair Chain思路解析
- python3 正则表达式检验词组搭配
- 正则表达式-记录
- post与get区别
- tensorflow输出权重值和偏差
- RSA公钥私钥生成
- 一个注册页面(横线上输入信息(input)及其交互)
- springmvc单元测试
- openstack实现私有云的搭建