#34. 「网络流 24 题」最长 k 可重区间集

「网络流 24 题」最长 k 可重区间集

题目描述

给定实直线 L L n n 个开区间组成的集合 I I ,和一个正整数 k k ,试设计一个算法,从开区间集合 I I 中选取出开区间集合 SI S \subseteq I ,使得在实直线 L L 的任何一点 x x S S 中包含点 x x 的开区间个数不超过 k k 。且 zSz \sum\limits_{z \in S} | z | 达到最大。这样的集合 S S 称为开区间集合 I I 的最长 k k 可重区间集。zSz \sum\limits_{z \in S} | z | 称为最长 k k 可重区间集的长度。

对于给定的开区间集合 I I 和正整数 k k ,计算开区间集合 I I 的最长 k k 可重区间集的长度。

输入格式

文件的第 1 1 行有 2 2 个正整数 n n k k ,分别表示开区间的个数和开区间的可重迭数。
接下来的 n n 行,每行有 2 2 个整数 li l_i ri r_i ,表示开区间的左右端点坐标,注意可能有 li>ri l_i > r_i ,此时请将其交换

输出格式

输出最长 k k 可重区间集的长度。

样例

4 2
1 7
6 8
7 10
9 13
15

数据范围与提示

1n500,1k3 1 \leq n \leq 500, 1 \leq k \leq 3