看起来是个经典的题型,得积累起来。。。建图方式也是相当神奇。。
离散化区间之后直接从i向i+1连容量为k费用为0的边,对于每个区间,从l向r连容量为1费用为区间长度的边
然后直接跑最大费用流即可。。。
/**
* ┏┓ ┏┓
* ┏┛┗━━━━━━━┛┗━━━┓
* ┃ ┃
* ┃ ━ ┃
* ┃ > < ┃
* ┃ ┃
* ┃... ⌒ ... ┃
* ┃ ┃
* ┗━┓ ┏━┛
* ┃ ┃ Code is far away from bug with the animal protecting
* ┃ ┃ 神兽保佑,代码无bug
* ┃ ┃
* ┃ ┃
* ┃ ┃
* ┃ ┃
* ┃ ┗━━━┓
* ┃ ┣┓
* ┃ ┏┛
* ┗┓┓┏━┳┓┏┛
* ┃┫┫ ┃┫┫
* ┗┻┛ ┗┻┛
*/
#include
#include
#include
#include
#include
#include
#include
P3358 最长k可重区间集问题
题目描述
对于给定的开区间集合 I 和正整数 k,计算开区间集合 I 的最长 k可重区间集的长度。
输入输出格式
输入格式:
的第 1 行有 2 个正整数 n和 k,分别表示开区间的个数和开区间的可重迭数。接下来的 n行,每行有 2 个整数,表示开区间的左右端点坐标。
输出格式:
将计算出的最长 k可重区间集的长度输出
输入输出样例
输入样例#1:复制
4 2
1 7
6 8
7 10
9 13
输出样例#1:复制
15
说明
对于100%的数据, 1≤n≤5001\le n\le 5001≤n≤500 , 1≤k≤31\le k\le 31≤k≤3