#343. 最长k可重区间集问题

最长k可重区间集问题

题目描述

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

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

输入格式

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

输出格式

输出最长 k\red{k} 可重区间集的长度。

样例

输入样例

4 2
1 7
6 8
7 10
9 13

输出样例

15

提示

1n500,1k3\red{1 \leq n \leq 500, 1 \leq k \leq 3}