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 ...
随机推荐
- PAT L3-020 至多删三个字符
https://pintia.cn/problem-sets/994805046380707840/problems/994805046946938880 给定一个全部由小写英文字母组成的字符串,允许 ...
- yum 命令
yum( Yellow dog Updater, Modified)是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器. 基於RPM包管理,能够从指定的服务器自动下载RPM包 ...
- Git之项目使用
现在最为盛行的版本控制器,非git莫属了, 那就看看在项目中我们是如何使用它的吧 一. 在已经存在秘钥对的情况下,我们需要在本地进行相关配置 git config --global user.name ...
- 渗透测试平台bwapp简单介绍及安装
先来介绍一下bwapp bwapp是一款非常好用的漏洞演示平台,包含有100多个漏洞 SQL, HTML, iFrame, SSI, OS Command, XML, XPath, LDAP, PHP ...
- 逻辑斯特回归tensorflow实现
calss #!/usr/bin/python2.7 #coding:utf-8 from __future__ import print_function import tensorflow as ...
- 虚拟机安装CentOS7之后没有ip的问题
CentOS 7 默认是不启动网卡的(ONBOOT=no),主要是修改一下网上配置,然后重起便可,看这篇博客操作: https://blog.csdn.net/dancheren/article/de ...
- Day 5-2 类的继承和派生,重用
类的继承 派生 在子类中重用父类 组合 抽象类 定义: 继承指的是类与类之间的关系,是一种什么“是”什么的关系,继承的功能之一就是用来解决代码重用问题. 继承是一种创建新类的方式,在python中,新 ...
- 用mescroll实现无限上拉增加数据,下拉刷新数据 (学习笔记)
最近自己做一个web app需要用到上拉查询下页数据,网上看了很多很多帖子,发现并不能快速的套用,总是会出现各种问题无法使用,于是无奈自己跑去看了官方api文档,终于做了出来,至此做个笔记,以后用到可 ...
- 一个实际的案例介绍Spring Boot + Vue 前后端分离
介绍 最近在工作中做个新项目,后端选用Spring Boot,前端选用Vue技术.众所周知现在开发都是前后端分离,本文就将介绍一种前后端分离方式. 常规的开发方式 采用Spring Boot 开发项目 ...
- SpringBoot之加载自定义配置文件
SpringBoot默认加载配置文件名为:application.properties和application.yml,如果需要使用自定义的配置文件,则通过@PropertySource注解指定. J ...