【有源汇上下界费用流】BZOJ 3876 [Ahoi2014]支线剧情
题目链接:
http://www.lydsy.com:808/JudgeOnline/problem.php?id=3876
题目大意:
给定一张拓扑图(有向无环图),每条边有边权,每次只能从第一个点出发沿着拓扑图走一条路径,求遍历所有边所需要的最小边权和。
题目思路:
【有源汇上下界费用流】
Orz两位神犇,以下思路借鉴自
http://hzwer.com/6224.html
http://blog.csdn.net/popoqqq/article/details/43024221
建图如下:
设汇t,源s=1,超级源S,超级汇T。
本质是每条边的下界为1,上界为MAX,跑一遍有源汇的上下界最小费用最小流。(因为上界无穷大,所以只要满足所有下界的最小费用最小流)
对每个点x:
从x到t连一条费用为0,流量为MAX的边,表示可以任意停止当前的剧情(接下来的剧情从更优的路径去走,画个样例就知道了)
对于每一条边权为z的边x->y:
从S到y连一条流量为1,费用为z的边,代表这条边至少要被走一次。
从x到y连一条流量为MAX,费用为z的边,代表这条边除了至少走的一次之外还可以随便走。
从x到T连一条流量为1,费用为0的边。(注意是每一条x->y的边都连,或者你可以记下x的出边数Kx,连一次流量为Kx,费用为0的边)。
建完图后从S到T跑一遍费用流,即可。(当前跑出来的就是满足上下界的最小费用最小流了)
//
//by coolxxx
//
#include<iostream>
#include<algorithm>
#include<string>
#include<iomanip>
#include<memory.h>
#include<time.h>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<stdbool.h>
#include<math.h>
#define min(a,b) ((a)<(b)?(a):(b))
#define max(a,b) ((a)>(b)?(a):(b))
#define abs(a) ((a)>0?(a):(-(a)))
#define lowbit(a) (a&(-a))
#define sqr(a) (a)*(a)
#define swap(a,b) (a)^=(b),(b)^=(a),(a)^=(b)
#define eps 1e-8
#define MAX 0x7f7f7f7f
#define INF 20000
#define PI 3.1415926535897
#define N 304
#define M 5004
using namespace std;
int n,m,cas,lll,ans;
int last[N],d[N];
int S,T,s,t,qq[M+M];
bool K;
bool mark[N];
struct data
{
int to,from,next,f,c;
}e[M*];
inline int Read()
{
int x=,f=;char ch=getchar();
while(ch>'' || ch<''){if(ch=='-')f=-;ch=getchar();}
while(ch>='' && ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
void add(int u,int f,int w,int c)
{
e[++lll].to=f;e[lll].from=u;
e[lll].next=last[u];last[u]=lll;
e[lll].f=w;e[lll].c=c;
}
void link(int u,int v,int w,int c)
{
add(u,v,w,c);
add(v,u,,-c);
}
void build()
{
int i,j,x,y,z;
memset(last,,sizeof(last));
lll=;ans=;
s=,t=n+;
S=n+,T=n+;
for(i=;i<=n;i++)
{
j=Read();
link(i,t,MAX,);
while(j--)
{
y=Read();z=Read();
link(i,y,MAX,z);
link(S,y,,z);
link(i,T,,);
}
}
link(t,s,MAX,);
}
bool spfa(int S,int T)
{
int i,now;
memset(mark,,sizeof(mark));
memset(d,0x7f,sizeof(d));
int head=M-,tail=M;
qq[M]=T;
d[T]=;mark[T]=;
while(head++<tail)
{
now=qq[head];
for(i=last[now];i;i=e[i].next)
{
if(e[i^].f> && d[now]-e[i].c<d[e[i].to])
{
d[e[i].to]=d[now]-e[i].c;
if(!mark[e[i].to])
{
if(d[e[i].to]<d[qq[head]])
qq[head--]=e[i].to;
else
qq[++tail]=e[i].to;
mark[e[i].to]=;
}
}
}
mark[now]=;
}
if(d[S]==MAX)return ;
else return ;
}
int dfs(int u,int f,int T)
{
int v,i,tt,asp=;
if(u==T)
{
K=;
return f;
}
mark[u]=;
for(i=last[u];i;i=e[i].next)
{
if(!mark[e[i].to] && e[i].f> && d[u]-e[i].c==d[e[i].to])
{
tt=dfs(e[i].to,min(e[i].f,f-asp),T);
e[i].f-=tt;
e[i^].f+=tt;
ans+=tt*e[i].c;
asp+=tt;
if(asp==f)
return f;
}
}
return asp;
}
void mincostflow(int S,int T)
{
while()
{
if(!spfa(S,T))break;
K=;
while(K)
{
K=;
memset(mark,,sizeof(mark));
dfs(S,MAX,T);
}
}
}
int main()
{
#ifndef ONLINE_JUDGE
// freopen("1.txt","r",stdin);
// freopen("2.txt","w",stdout);
#endif
int i,j;
while(~scanf("%d",&n) && n)
{
build();
mincostflow(S,T);
printf("%d\n",ans);
}
return ;
} /*
// //
*/
【有源汇上下界费用流】BZOJ 3876 [Ahoi2014]支线剧情的更多相关文章
- BZOJ 2502 清理雪道(有源汇上下界最小流)
题面 滑雪场坐落在FJ省西北部的若干座山上. 从空中鸟瞰,滑雪场可以看作一个有向无环图,每条弧代表一个斜坡(即雪道),弧的方向代表斜坡下降的方向. 你的团队负责每周定时清理雪道.你们拥有一架直升飞机, ...
- BZOJ 2502 清理雪道/ Luogu P4843 清理雪道 (有源汇上下界最小流)
题意 有一个有向无环图,求最少的路径条数覆盖所有的边 分析 有源汇上下界最小流板题,直接放代码了,不会的看dalao博客:liu_runda 有点长,讲的很好,静心看一定能看懂 CODE #inclu ...
- 【有源汇上下界最大流】ZOJ 3229 Shoot the Bullet
题目链接: http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3229 题目大意: n天给m个女孩拍照(1<=n<= ...
- POJ2396 Budget [有源汇上下界可行流]
POJ2396 Budget 题意:n*m的非负整数矩阵,给出每行每列的和,以及一些约束关系x,y,>=<,val,表示格子(x,y)的值与val的关系,0代表整行/列都有这个关系,求判断 ...
- 有源汇上下界可行流(POJ2396)
题意:给出一个n*m的矩阵的每行和及每列和,还有一些格子的限制,求一组合法方案. 源点向行,汇点向列,连一条上下界均为和的边. 对于某格的限制,从它所在行向所在列连其上下界的边. 求有源汇上下界可行流 ...
- BZOJ_2502_清理雪道_有源汇上下界最小流
BZOJ_2502_清理雪道_有源汇上下界最小流 Description 滑雪场坐落在FJ省西北部的若干座山上. 从空中鸟瞰,滑雪场可以看作一个有向无环图,每条弧代表一个斜坡(即雪道), ...
- 【Loj117】有源汇上下界最小流(网络流)
[Loj117]有源汇上下界最小流(网络流) 题面 Loj 题解 还是模板题. #include<iostream> #include<cstdio> #include< ...
- ZOJ 3229 Shoot the Bullet(有源汇上下界最大流)
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=3442 题目大意: 一个屌丝给m个女神拍照,计划拍照n天,每一天屌丝给 ...
- 计蒜客 31447 - Fantastic Graph - [有源汇上下界可行流][2018ICPC沈阳网络预赛F题]
题目链接:https://nanti.jisuanke.com/t/31447 "Oh, There is a bipartite graph.""Make it Fan ...
随机推荐
- O2O的理解
O2O 就是把线上和线下的优势完美结合,网上优惠价格,线下享受贴身服务!O2O 还可以实现不同商家的联盟 两年前的微博营销,现在没落了,那么微信营销呢,只能说来的太快了.线上来筛选服务和产品,所有的交 ...
- ftp不能上传解决办法
自己的服务器,然后我分好ftp,有一天,有个客户要传东西,发现怎么也传不上,但是可以下载,,,,弄了半天,目录权限也是完全访问,但还是不行,原来是serv-u分配的空间小了啊,所以只能下载不能上传.. ...
- Android开发手记(25) 简单Service的实现
本文将通过实现一个简单的Service发送简单消息,然后通过一个BroadcastReceiver接收Service发送的消息,从而改变一个TextView的文本颜色. 这里,我们需要三个java文件 ...
- 表单提交对chrome记住密码的影响
在处理注册.登录等含有用户名,密码的元素的表单时,chrome会主动的提示记住密码,然而这个功能在用户名的选择上真是耐人寻味,它总是寻找离password input控件最近的那一个文本框的内容,作为 ...
- xcode本地运行H5游戏可以吗?
答案是不可以!!! 不可以!!! 不可以!!! 有时候很郁闷的接受一个需求,然后以为自己能力不行,或者是代码写错,还是哪里了解不够,然而并不是啊!!! MD的我想说有些事是行不通的的!! 好了,平静下 ...
- Junit4_单元测试
不多说,直接练习学习. 1.将Junit4单元测试包引入项目:项目右键——“属性”,选择“Java Build Path”,然后到右上选择“Libraries”标签,之后在最右边点击“Add Libr ...
- hdoj 2040
#include<stdio.h>int i,j,s1,s2;int cha(int a,int b){ s1=0; s2=0; for(i=1;i<a;i++) { ...
- POJ2104 K-th Number 静态区间第k最值 平方分割
干掉这道题的那一刻,我只想说:我终于**的AC了!!! 最终内存1344K,耗时10282ms,比起归并树.划分树以及其他各种黑科技,这个成绩并不算光彩⊙﹏⊙ 但至少,从最初的无数次TLE到最终的AC ...
- Facade 模式
在软件系统开发中经常回会遇到这样的情况,你实现了一些接口(模块),而这些接口(模块)都分布在几个类中(比如 A和 B.C.D) :A中实现了一些接口,B 中实现一些接口(或者 A代表一个独立模块,B. ...
- 【CF39E】【博弈论】What Has Dirichlet Got to Do with That?
Description You all know the Dirichlet principle, the point of which is that if n boxes have no less ...