我的作业部落有学习资料

可学的知识点

Dinic 模板

#define rg register
#define _ 10001
#define INF 2147483647
#define min(x,y) (x)<(y)?(x):(y)
using namespace std;
int n,m,s,t,record[_],num_of_edges=-,cur[_],team[],depth[_];
struct pp
{
int next,to,w;
}edge[(_<<)+(_<<)];
inline int read()
{
rg int save=,w=;rg char q=getchar();
while(q<''||q>''){if(q=='-')w=-;q=getchar();}
while(q>=''&&q<='')save=(save<<)+(save<<)+q-'',q=getchar();
return save*w;
}
inline void add(rg int from,rg int to,rg int ww)
{
edge[++num_of_edges]=(pp){record[from],to,ww};
record[from]=num_of_edges;
}
inline bool bfs()
{
rg int head=,tail=;
for(rg int i=;i<=n;++i)depth[i]=;//depth[]初值为-1,免得返回出发点
depth[s]=;
team[]=s;
do
{
head++;
rg int u=team[head];
for(rg int j=record[u];j!=-;j=edge[j].next)
{
rg int to=edge[j].to;
if((!depth[to])&&(edge[j].w>))
{
depth[to]=depth[u]+;
team[++tail]=to;
if(to==t)return ;
}
}
}while(head<tail);
return ;
}
int dfs(rg int u,rg int flow)//找到每条路上的最小残余流量,因此需在回溯时更新每条边的流量
{
if(u==t)return flow;
for(rg int &j=cur[u]/*当前弧优化*/;j!=-;j=edge[j].next)
{
rg int to=edge[j].to;
if(depth[to]==depth[u]+&&(edge[j].w>))
{
rg int D=dfs(to,min(flow,edge[j].w));//到终点的过程中一直在取min
if(D>)
{
edge[j].w-=D,edge[j^].w+=D;
return D;//每次只找一条可流通路满上(这里就不管现实中物理的联通器原理了)
} }
}
return ;
}
inline int Dinic()
{
rg int i,j,ans=;
while(bfs())
{
for(i=;i<=n;++i)cur[i]=record[i];
while(int now=dfs(s,INF))ans+=now;
}
return ans;
}
int main()
{
n=read(),m=read(),s=read(),t=read();
rg int i,j;
for(i=;i<=n;++i)record[i]=-;
for(i=;i<=m;++i)
{
rg int x=read(),y=read(),ww=read();
add(x,y,ww),add(y,x,);
}
printf("%d\n",Dinic());
return ;
}

最小费用最大流:

#define rg register
#define _ 5001
#define __ 50001
#define INF 2147483647
using namespace std;
int n,m,s,t,record[_],num_of_edges=,pre[_],res_flow,res_cost,dis[_],team[__<<];//以后num_of_edges都赋为 1 !!!
bool exist[_];
struct pp
{
int next,to,w,cost;
}edge[__<<];
inline int read()
{
rg int save=,w=;rg char q=getchar();
while(q<''||q>''){if(q=='-')w=-;q=getchar();}
while(q>=''&&q<='')save=(save<<)+(save<<)+q-'',q=getchar();
return w*save;
}
inline void add(rg int from,rg int to,rg int ww,rg int f)
{
edge[++num_of_edges]=(pp){record[from],to,ww,f};
record[from]=num_of_edges;
}
inline bool SPFA()
{
rg int head=,tail=;
for(rg int i=;i<=n;++i)exist[i]=,dis[i]=INF;
dis[s]=;
team[]=s;
do
{
head++;
rg int i=team[head];
exist[i]=;
for(rg int j=record[i];j;j=edge[j].next)
{
rg int to=edge[j].to;
if(edge[j].w>&&dis[to]>dis[i]+edge[j].cost)
{
dis[to]=dis[i]+edge[j].cost;
pre[to]=j;
if(!exist[to])team[++tail]=to,exist[to]=;
}
}
}while(head<tail);
return dis[t]!=INF;
}
inline void doit()
{
while(SPFA())
{
rg int flow=INF;
for(rg int i=pre[t];i;i=pre[edge[i^].to])
flow=min(flow,edge[i].w);
res_flow+=flow;
res_cost+=dis[t]*flow;
for(rg int i=pre[t];i;i=pre[edge[i^].to])
edge[i].w-=flow,edge[i^].w+=flow;
}
printf("%d %d\n",res_flow,res_cost);
}
int main()
{
n=read(),m=read(),s=read(),t=read();
rg int i,j;
for(i=;i<=m;++i)
{
rg int u=read(),v=read(),w=read(),f=read();
add(u,v,w,f),add(v,u,,-f);
}
doit();//实在不想用那个MCMF()
return ;
}

[模板]网络最大流 & 最小费用最大流的更多相关文章

  1. BZOJ 1834: [ZJOI2010]network 网络扩容(最大流+最小费用最大流)

    第一问直接跑最大流.然后将所有边再加一次,费用为扩容费用,容量为k,再从一个超级源点连一条容量为k,费用为0的边到原源点,从原汇点连一条同样的边到超级汇点,然  后跑最小费用最大流就OK了. ---- ...

  2. bzoj 1834: [ZJOI2010]network 网络扩容【最大流+最小费用最大流】

    第一问直接跑最大流即可.建图的时候按照费用流建,费用为0. 对于第二问,在第一问dinic剩下的残量网络上建图,对原图的每条边(i,j),建(i,j,inf,cij),表示可以用c的花费增广这条路.然 ...

  3. 最大流 && 最小费用最大流模板

    模板从  这里   搬运,链接博客还有很多网络流题集题解参考. 最大流模板 ( 可处理重边 ) ; const int INF = 0x3f3f3f3f; struct Edge { int from ...

  4. BZOJ1834 [ZJOI2010]network 网络扩容(最小费用最大流)

    挺直白的构图..最小费用最大流的定义. #include<cstdio> #include<cstring> #include<queue> #include< ...

  5. 洛谷P2604 最大流+最小费用最大流

    题目链接:https://www.luogu.org/problem/P2604 题目描述 给定一张有向图,每条边都有一个容量C和一个扩容费用W.这里扩容费用是指将容量扩大1所需的费用.求: 1. 在 ...

  6. POJ - 2516 Minimum Cost(最小费用最大流)

    1.K种物品,M个供应商,N个收购商.每种物品从一个供应商运送到一个收购商有一个单位运费.每个收购商都需要K种物品中的若干.求满足所有收购商需求的前提下的最小运费. 2.K种物品拆开来,分别对每种物品 ...

  7. P3381 【模板】最小费用最大流

    P3381 [模板]最小费用最大流 题目描述 如题,给出一个网络图,以及其源点和汇点,每条边已知其最大流量和单位流量费用,求出其网络最大流和在最大流情况下的最小费用. 输入输出格式 输入格式: 第一行 ...

  8. 【网络流#2】hdu 1533 - 最小费用最大流模板题

    最小费用最大流,即MCMF(Minimum Cost Maximum Flow)问题 嗯~第一次写费用流题... 这道就是费用流的模板题,找不到更裸的题了 建图:每个m(Man)作为源点,每个H(Ho ...

  9. 洛谷P3381 最小费用最大流模板

    https://www.luogu.org/problem/P3381 题目描述 如题,给出一个网络图,以及其源点和汇点,每条边已知其最大流量和单位流量费用,求出其网络最大流和在最大流情况下的最小费用 ...

随机推荐

  1. SQL server 聚集索引与主键的区别

    主键是一个约束(constraint),他依附在一个索引上,这个索引可以是聚集索引,也可以是非聚集索引. 所以在一个(或一组)字段上有主键,只能说明他上面有个索引,但不一定就是聚集索引. 例如下面: ...

  2. elasticsearch 深入 —— Top Hits Aggregation

    Top Hits Aggregation top_hits指标聚合器跟踪正在聚合的最相关文档. 此聚合器旨在用作子聚合器,以便可以按桶聚合最匹配的文档. top_hits聚合器可以有效地用于通过桶聚合 ...

  3. 【ASE高级软件工程】Alpha 阶段 backend组 scrum1 记录

    本次会议于11月4日,19:10 在微软北京西二号楼13478召开,持续40分钟. 与会人员:Haifeng Chen, Zhikai Chen, Hao Wang, Jia Ning 请假: Xin ...

  4. 关于同PC上存在多个版本的GeneXus

    如题 有的时候需要在不同的版本上开发  如我一般 有四个版本IDE 那么有的时候可能在安装的时候 提示安装失败 比如这样 这个时候你需要将安装好的GeneXus安装目录 全部备份一下 然后  从控制面 ...

  5. linux篇之Nginx web服务器简单部署

    一.安装部署nginx 1. 部署前先对nginx介绍下别嫌BB: 如果你听说或使用过Apache软件,那么很快就会熟悉Nginx软件,与Apache软件类似, Nginx(“engine x”)是一 ...

  6. 灰常牛逼的命令行备忘录 navi

    灰常牛逼的命令行备忘录 navi 1. navi命令简介 1.1 navi命令简介 命令行是非常高效的工具,但一个很常见的现象是,很多命令行过一段时间就容易忘.举个栗子,如果我们常用 git 命令行管 ...

  7. docker运行redis

    查询镜像: zhoumatoMBP:~ zhou$ docker search redis NAME DESCRIPTION STARS OFFICIAL AUTOMATED redis Redis ...

  8. BZOJ1822 [JSOI2010]Frozen Nova 冷冻波 二分+最大流

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=1822 题解 好久没做网络流的,都没有想到网络流... 首先暴力判断一下一个巫妖和一个精灵之间能 ...

  9. Java double转long方法

    Java double转long方法 double random = Math.round(Math.random()*10000); long l = new Double(random).long ...

  10. Mac下通过npm安装webpack 、vuejs,以及引入jquery、bootstrap等(初稿)

    前言: 初次接触前端开发技术,一些方向都是在同事的指引和自己的探索后,跑了个简易web,迈入全栈系列.由于是事后来的文章,故而暂只是杂记,写的粗略且不清晰,后续将补之. 主要参考文档: http:// ...