<题目链接>

题目大意:

一天有N个小时,有m个节目(每种节目都有类型),有k个人,连续看相同类型的节目会扣w快乐值。每一种节目有都一个播放区间[l,r]。每个人同一时间只能看一个节目,看完可以获得快乐值,每个节目只能被人看一次。问最多可以获得多少快乐?

解题分析:

本题用费用流求解的方式还是比较直观的。因为本题要求的是最大费用,所以我们需要建图的时候需要将所有实际费用取反,然后将最后最小费用最大流求出的答案取反,就是要求的最大费用。具体建图过程见代码:

#include <bits/stdc++.h>
using namespace std; #define clr(a,b) memset(a,b,sizeof(a))
template<typename T>
inline void read(T&x){
x=;int f=;char c=getchar();
while(c<'' || c>''){ if(c=='-')f=-;c=getchar(); }
while(c>='' && c<=''){ x=x*+c-'';c=getchar(); }
x*=f;
} //最小费用最大流模板
struct MCMF{
static const int N = 5e4+, M = 5e5+, INF = 0x7fffffff; int n, m, head[N], s, t, cnt;
int dist[N], inq[N], pre[N], incf[N];
int mxflow, mncost;
struct Edge{ int to, cap, cost, next; } edge[M * ]; inline void init(int l, int r, int ss, int tt){
//for(int i = l; i <= r; i++ ){head[i] = -1;}
memset(head, -, sizeof(head));
s = ss, t = tt, cnt = ;
mxflow = mncost = ;
}
inline void add(int u,int v,int cap,int cost){
edge[++cnt]=(Edge){v,cap,cost,head[u]};head[u]=cnt;
edge[++cnt]=(Edge){u,,-cost,head[v]};head[v]=cnt;
} bool spfa(int s, int t){ //slf优化的spfa(双端队列优化)
for(int i = ; i < N; i++)
dist[i] = INF, inq[i] = ;
clr(pre,);
deque<int>q;
inq[s]=,dist[s] = ;
q.push_back(s);
incf[s] = INF;
while(!q.empty()){
int u = q.front();q.pop_front();
inq[u] = ;
for(int i=head[u];~i;i=edge[i].next){
int v=edge[i].to,cap=edge[i].cap,cost=edge[i].cost;
if(cap> && dist[v]>dist[u]+cost){ //更新每个点的最小费用
dist[v]=dist[u]+cost;
incf[v]=min(incf[u], cap); //得到v点所在路径上的最小容量
pre[v]=i; //记录下这个点的前驱正向边
if(!inq[v]){
inq[v]=;
if(q.empty() || dist[v]>dist[q.front()])q.push_back(v);
else q.push_front(v); //如果最小费用小于等于队首,直接塞入队列首
}
}
}
}
return dist[t]!=INF;
}
void update(int s,int t){
int x=t;
while(x!=s){
int pos=pre[x];
edge[pos].cap-=incf[t];
edge[pos^].cap+=incf[t];
x=edge[pos^].to;
}
mxflow+=incf[t];
mncost+=dist[t]*incf[t];
}
void minCostMaxFlow(int s,int t){
while(spfa(s,t))
update(s,t);
}
}mcmf; const int NN = + ;
struct Node{ int l, r, w, fp; } node[NN]; int st,ed;
inline void GetMap(){
int n,m,k,w;
read(n);read(m);read(k);read(w);
st=,ed=*m+; //0代表源点,2*m+1代表慈元典,ed代表汇点
mcmf.init(st,ed,st,ed);
mcmf.add(st,*m+,k,); //源点向次源点连一条容量为k,费用为0的边
for(int i=;i<=m;i++)
scanf("%d%d%d%d",&node[i].l,&node[i].r,&node[i].w,&node[i].fp);
for(int i=;i<=m;i++){
for(int j=;j<=m;j++){
if(i==j)continue;
if(node[i].r<=node[j].l) //对于那些满足条件的video, i的出点向j的入点连一条容量为1,费用为0(或者如果这两个点类型相同的话,费用就为W,因为本题是将所有费用置为它的相反数了)
mcmf.add(i+m,j,,(node[i].fp==node[j].fp)?w:); //因为本题是求最大费用,所以要将所有费用取反,这里就是 w
}
}
for(int i=;i<=m;i++)
mcmf.add(i,i+m,,-node[i].w); //拆点,所有点的入点向入点连一条容量为1,费用为node[i].w的边
for(int i=;i<=m;i++)
mcmf.add(*m+,i,,); //源点向所有的点连上一条容量为1,费用为0的边
for(int i=;i<=m;i++)
mcmf.add(i+m,ed,,); //所有点的出度连一条容量为1,费用为0的边
}
inline void Solve(){
mcmf.minCostMaxFlow(st,ed);
printf("%d\n",-mcmf.mncost); //取相反数,就是实际意义上的最大费用
}
int main(){
int T;cin>>T;
while(T--){
GetMap();
Solve();
}
}

HDU 6437 Problem L.Videos (最大费用)【费用流】的更多相关文章

  1. HDU - 6437 Problem L.Videos 2018 Multi-University Training Contest 10 (最小费用最大流)

    题意:M个影片,其属性有开始时间S,结束时间T,类型op和权值val.有K个人,每个人可以看若干个时间不相交的影片,其获得的收益是这个影片的权值val,但如果观看的影片相邻为相同的属性,那么收益要减少 ...

  2. hdu6437 Problem L.Videos(网络流)

    Problem L.Videos Problem Description: C-bacteria takes charge of two kinds of videos: ’The Collectio ...

  3. HDU 6343.Problem L. Graph Theory Homework-数学 (2018 Multi-University Training Contest 4 1012)

    6343.Problem L. Graph Theory Homework 官方题解: 一篇写的很好的博客: HDU 6343 - Problem L. Graph Theory Homework - ...

  4. [hdu6437]Problem L. Videos

    题目大意:有$n$个小时,有$m$个节目(每种节目都有类型$0/1$),有$k$个人,一个人连续看相同类型的节目会扣$w$快乐值. 每一种节目有都一个播放区间$[l,r]$.每个人同一时间只能看一个节 ...

  5. HDU 6330.Problem L. Visual Cube-模拟到上天-输出立方体 (2018 Multi-University Training Contest 3 1012)

    6330.Problem L. Visual Cube 这个题就是输出立方体.当时写完怎么都不过,后来输出b<c的情况,发现这里写挫了,判断失误.加了点东西就过了,mdzz... 代码: //1 ...

  6. HDU 6343 - Problem L. Graph Theory Homework - [(伪装成图论题的)简单数学题]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6343 Time Limit: 2000/1000 MS (Java/Others) Memory Li ...

  7. HDU 6437 最(大) 小费用最大流

    Problem L.Videos Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 524288/524288 K (Java/Other ...

  8. HDU 5988.Coding Contest 最小费用最大流

    Coding Contest Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)To ...

  9. hdu 3395(KM算法||最小费用最大流(第二种超级巧妙))

    Special Fish Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Tota ...

随机推荐

  1. 标签传播算法(Label Propagation Algorithm, LPA)初探

    0. 社区划分简介 0x1:非重叠社区划分方法 在一个网络里面,每一个样本只能是属于一个社区的,那么这样的问题就称为非重叠社区划分. 在非重叠社区划分算法里面,有很多的方法: 1. 基于模块度优化的社 ...

  2. 【Sublime Text】sublime text 安装插件方法总结

    #使用Package Control组件安装插件 1.安装Package Control组件 按 Ctrl+` 调出console(注:避免热键冲突,可以在界面上操作  View-show conso ...

  3. Java裸写爬虫技术,运用多线程技术,高效爬取某个医疗机构网站数据

    最近喜欢上了数据的庞大的感觉,就爬取了一下某个医疗机构网站医疗数据,由于数据量庞大,只爬取了江西省的各个市的各个医院的各个科室的各个科室.中各种信息.其中用的持久层技术是hibernate框架,和用到 ...

  4. Python学习第二节——基础知识

    # !/usr/bin/edv python    脚本语言的第一行,目的就是指出,你想要你的这个文件中的代码用什么可执行程序去运行它.# -*- coding:UTF-8 -*-    标明编码注释 ...

  5. 关于C的全局变量

    一般来说,不会将全局变量的定义写在头文件中.因为如果多个C源文件都添加了头文件,很容易引起重复定义的问题,这时候一般编译器都会提示.正确的做法是在C源文件中定义一个全局变量,在头文件中加入全局变量的声 ...

  6. andriod webview和h5

    1.WebBrowserActivity extends BaseActivity 2.setContentView(R.layout.activity_web_html); <WebView ...

  7. KindEditor 取不到值 与清空不掉值

    var editor; KindEditor.ready(function(K) { editor = K.create('textarea[name="content"]', { ...

  8. Apple Tree POJ - 2486 (树形dp)

    题目链接: D - 树形dp  POJ - 2486 题目大意:一颗树,n个点(1-n),n-1条边,每个点上有一个权值,求从1出发,走V步,最多能遍历到的权值 学习网址:https://blog.c ...

  9. spring boot集成swagger,自定义注解,拦截器,xss过滤,异步调用,guava限流,定时任务案例, 发邮件

    本文介绍spring boot集成swagger,自定义注解,拦截器,xss过滤,异步调用,定时任务案例 集成swagger--对于做前后端分离的项目,后端只需要提供接口访问,swagger提供了接口 ...

  10. 基于Spring Security OAuth2搭建的Spring Cloud 认证中心

    Github传送门:https://github.com/13babybear/bounter-springcloud 实现功能有: 整合JWT 刷新Token 自定义客户端储存 自定义用户储存 资源 ...