poj3680 Intervals (费用流)
建图((x,y,c,l)表示x到y,费用c,流量l)
(S,1,0,K)
(i,i+1,0,K) 这个边上的流量,表示i还可以被覆盖的次数
(N,T,0,K)
(i,j,w,1)对于权值为w的区间[i,j]
然后跑最大费用最大流
因为没有负权值,所以肯定尽量跑满
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<queue>
#define CLR(a,x) memset(a,x,sizeof(a))
#define MP make_pair
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int,int> pa;
const int maxn=,maxp=,inf=1e9; inline ll rd(){
ll x=;char c=getchar();int neg=;
while(c<''||c>''){if(c=='-') neg=-;c=getchar();}
while(c>=''&&c<='') x=x*+c-'',c=getchar();
return x*neg;
} int l[maxn],r[maxn],w[maxn],N,M,K,tmp[maxp],S=,T=;
struct Edge{
int b,l,ne,c;
}eg[maxp*];
int egh[maxp],ect=;
int dis[maxp],fae[maxp];
bool flag[maxp]; inline void adeg(int a,int b,int c,int l){
// printf("~%d %d %d %d\n",a,b,c,l);
eg[++ect].b=b,eg[ect].l=l,eg[ect].c=c,eg[ect].ne=egh[a],egh[a]=ect;
eg[++ect].b=a,eg[ect].l=,eg[ect].c=-c,eg[ect].ne=egh[b],egh[b]=ect;
} queue<int> q;
inline bool spfa(){
CLR(dis,-);dis[S]=;
CLR(fae,);q.push(S);
while(!q.empty()){
int p=q.front();q.pop();
// printf("~%d %d\n",p,dis[S]);
flag[p]=;
for(int i=egh[p];i;i=eg[i].ne){
int b=eg[i].b;if(!eg[i].l) continue;
// printf("!!%d %d %d\n",b,eg[i].c,eg[i].l);
if(dis[b]<dis[p]+eg[i].c){
dis[b]=dis[p]+eg[i].c;
fae[b]=i;
if(!flag[b]) q.push(b),flag[b]=;
}
}
}return dis[T]>=;
} int main(){
//freopen("","r",stdin);
int i,j,k;
for(int t=rd();t;t--){
N=rd(),K=rd();
for(i=;i<=N;i++){
tmp[i]=l[i]=rd(),tmp[i+N]=r[i]=rd(),w[i]=rd();
}sort(tmp+,tmp+N+N+);
int M=unique(tmp+,tmp+N+N+)-tmp-;
CLR(egh,);ect=;
for(i=;i<=N;i++){
l[i]=lower_bound(tmp+,tmp+M+,l[i])-tmp;
r[i]=lower_bound(tmp+,tmp+M+,r[i])-tmp;
adeg(l[i],r[i],w[i],);
}
for(i=;i<M;i++){
adeg(i,i+,,inf);
}adeg(M,T,,K);adeg(S,,,K);
int ans=;
while(spfa()){
int mi=inf;
for(i=T;i;i=eg[fae[i]^].b){
if(fae[i]) mi=min(mi,eg[fae[i]].l);
}
for(i=T;i;i=eg[fae[i]^].b){
eg[fae[i]].l-=mi,eg[fae[i]^].l+=mi;
}
ans+=mi*dis[T];
}
printf("%d\n",ans);
}
return ;
}
poj3680 Intervals (费用流)的更多相关文章
- poj 3680 Intervals(费用流)
http://poj.org/problem?id=3680 巧妙的构图. 题目:给定N个区间(ai,bi)权值wi,求最大权和且每个点最多覆盖K次. 构图:将区间端点离散化,将第i个点连第i+1个点 ...
- poj3680 Intervals 区间k覆盖问题 最小费用最大流 建图巧妙
/** 题目:poj3680 Intervals 区间k覆盖问题 最小费用最大流 建图巧妙 链接:http://poj.org/problem?id=3680 题意:给定n个区间,每个区间(ai,bi ...
- POJ-3680:Intervals (费用流)
You are given N weighted open intervals. The ith interval covers (ai, bi) and weighs wi. Your task i ...
- 【POJ3680】Intervals(费用流)
题意:有n条线段,每条有起点,终点和一个权值 要求选取一些线段,使它们的权值和最大,并且使每一个点被覆盖不超过k次 1 ≤ K ≤ N ≤ 200 1 ≤ ai < bi ≤ 100,000, ...
- POJ3680 Intervals —— 区间k覆盖问题(最小费用流)
题目链接:https://vjudge.net/problem/POJ-3680 Intervals Time Limit: 5000MS Memory Limit: 65536K Total S ...
- hdu-5988 Coding Contest(费用流)
题目链接: Coding Contest Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Ot ...
- POJ2195 Going Home[费用流|二分图最大权匹配]
Going Home Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 22088 Accepted: 11155 Desc ...
- BZOJ3130: [Sdoi2013]费用流[最大流 实数二分]
3130: [Sdoi2013]费用流 Time Limit: 10 Sec Memory Limit: 128 MBSec Special JudgeSubmit: 960 Solved: 5 ...
- 洛谷 1004 dp或最大费用流
思路: dp方法: 设dp[i][j][k][l]为两条没有交叉的路径分别走到(i,j)和(k,l)处最大价值. 则转移方程为 dp[i][j][k][l]=max(dp[i-1][j][k-1][l ...
随机推荐
- php开发之系统函数
一些常用的php开发之系统函数的使用,可以使我们的开发效率,事倍功半 1) BC高精度函数库 2)
- DVWA学习笔记-----环境搭建
DVWA是一款渗透测试的演练系统,在圈子里是很出名的.如果你需要入门,那么就选它了. 我们通常将演练系统称为靶机,下面请跟着我一起搭建DVWA测试环境. 安装PHP集成环境 我这里用的是phpstu ...
- Python解释器有哪些?Python解释器种类
Python是一门解释器语言,代码想运行,必须通过解释器执行,Python存在多种解释器,分别基于不同语言开发,每个解释器有不同的特点,但都能正常运行Python代码,以下是常用的五种Python解释 ...
- Docker以及K8S学习总结----From各位大神...
Docker的安装使用. 1. 修改yum源到境内站点: wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/re ...
- SSH框架整合实现Java三层架构实例(一)
HTML前台发送请求代码: <tr> <td>选择收派时间</td> <td> <input type="text" name ...
- linux audit审计(4)--audit的日志切分,以及与rsyslog的切分协同使用
audit的规则配置稍微不当,就会短时间内产生大量日志,所以这个规则配置一定要当心.当audit日志写满后,可以看到如下场景: -r-------- 1 root root 8388609 Mar 3 ...
- LOADING Redis is loading the dataset in memory Redis javaAPI实例
今天在实现Redis客户端API操作Jedis的八种调用方式详解中,遇到了LOADING Redis is loading the dataset in memory错误,经过多番查找资料,找到了解决 ...
- EChart.js 笔记一
一直对数据可视化比较感兴趣,当年 Alibaba 年报晚会上的大屏显示可谓是技惊四座,够震撼,将数据之美展现得淋漓尽致. 国内的前端数据可视化插件中,echart.js 算是热度很高的,也容易上手,算 ...
- Vue可复用过渡和动态过渡
前面的话 本文将详细介绍Vue可复用过渡和动态过渡 可复用过渡 过渡可以通过 Vue 的组件系统实现复用.要创建一个可复用过渡组件,需要做的就是将 <transition> 或者 < ...
- Nginx geo模块
geo 模块默认编译进nginx 可以通过--without-http_geo_module禁用 Syntax: geo [$address] $variable { ... } Default: — ...