不可以理解的是,测评站上的0ms是怎么搞出来的。

这一题在建立超级源点和超级汇点后就变得温和可爱了。其实它本身就温和可爱。对比了能够找到的题解:

(1)艾德蒙·卡普算法(2)迪尼克算法(3)改进版艾德蒙·卡普算法(MY METHOD)

不去管那个0ms的吧,那么(3)号算法最为美妙【它的别名是:ISAP】,时间可观。

这个就算是一个ISAP的模板吧(除了输入的难看的几行外,其余均是标准的大米饼牌模板!)

 #include<stdio.h>
#include<algorithm>
#include<queue>
#include<cstring>
#define go(i,a,b) for(int i=a;i<=b;i++)
#define fo(i,a,x) for(int i=a[x],v=e[i].v;i>-1;i=e[i].next,v=e[i].v)
#define mem(a,b) memset(a,b,sizeof(a))
using namespace std;const int N=
;
struct E{int v,next,flow,cap;}e[N*
N];
int n,n_power,n_user,m,S,T,head[N],k=
,d[N];
int
num[N],cur[N],preE[N],preN[N];
void ADD(int u,int v,int flow,int cap){e[k]=(E){v,head[u],flow,cap};head[u]=k++;}
void
BFS()
{
queue<int>q;bool vis[N]={};q.push(T);d[T]=
;
while(!
q.empty())
{
int u=
q.front();q.pop();
fo(i,head,u)if(!e[i].cap&&!
vis[v])
vis[v]=,d[v]=d[u]+
,q.push(v);
}
}
int aug(){int u,a=
;
u=T;while(u!=S){int i=preE[u];a=min(a,e[i].cap-e[i].flow);u=
preN[u];}
u=T;while(u!=S){int i=preE[u];e[i].flow+=a;e[i^].flow-=a;u=preN[u];}return
a;}
int main(){while(~scanf("%d%d%d%d",&n,&n_power,&n_user,&
m))
{
S=;T=n+;char _;mem(head,-
);
go(i,,m){int u,v,cap;scanf(" %c%d%c%d%c%d",&_,&u,&_,&v,&_,&
cap);
u++,v++;ADD(u,v,,cap);ADD(v,u,,
);}
go(i,,n_power){int v,cap;scanf(" %c%d%c%d",&_,&v,&_,&
cap);
v++;ADD(S,v,,cap);ADD(v,S,,
);}
go(i,,n_user){int u,cap;scanf(" %c%d%c%d",&_,&u,&_,&
cap);
u++;ADD(u,T,,cap);ADD(T,u,,);}BFS();mem(num,
); go(i,,n+)num[d[i]]++,cur[i]=head[i];
int u=S,flow=
;
while(d[S]<T+
)
{
u==T?flow+=aug(),u=S:;bool retreat=
;
fo(i,cur,u) if(e[i].cap>e[i].flow&&d[u]==d[v]+
)
{retreat=;cur[u]=preE[v]=i;preN[v]=u;u=v;break
;} if(!retreat)continue; int Min=T;fo(i,head,u){if(e[i].cap>e[i].flow)Min=min(Min,d[v]);}
if(!(--num[d[u]]))break;num[d[u]=Min+]++
;
cur[u]=head[u];u==S?:u=
preN[u];
}
printf("%d\n"
,flow);
}return ;}//Paul_Guderian

【改进版艾德蒙·卡普算法】

网络流两个学习要点:学会转化问题,学会几个模型?你是在质疑神奇大米饼的权威吗?那就给你个大米饼!

ZBH不给我玩以撒的结合…我写了这篇博客来表达愤怒!

【POJ 1459 power network】的更多相关文章

  1. POJ 1459 Power Network / HIT 1228 Power Network / UVAlive 2760 Power Network / ZOJ 1734 Power Network / FZU 1161 (网络流,最大流)

    POJ 1459 Power Network / HIT 1228 Power Network / UVAlive 2760 Power Network / ZOJ 1734 Power Networ ...

  2. poj 1459 Power Network

    题目连接 http://poj.org/problem?id=1459 Power Network Description A power network consists of nodes (pow ...

  3. poj 1459 Power Network【建立超级源点,超级汇点】

    Power Network Time Limit: 2000MS   Memory Limit: 32768K Total Submissions: 25514   Accepted: 13287 D ...

  4. poj 1459 Power Network : 最大网络流 dinic算法实现

    点击打开链接 Power Network Time Limit: 2000MS   Memory Limit: 32768K Total Submissions: 20903   Accepted:  ...

  5. POJ 1459 Power Network(网络流 最大流 多起点,多汇点)

    Power Network Time Limit: 2000MS   Memory Limit: 32768K Total Submissions: 22987   Accepted: 12039 D ...

  6. 2018.07.06 POJ 1459 Power Network(多源多汇最大流)

    Power Network Time Limit: 2000MS Memory Limit: 32768K Description A power network consists of nodes ...

  7. 网络流--最大流--POJ 1459 Power Network

    #include<cstdio> #include<cstring> #include<algorithm> #include<queue> #incl ...

  8. POJ 1459 - Power Network 【Ek-最大流】

    <题目链接> 题目大意:给出 n 个点,其中包括 np个发电站,nc 个消费者, 剩下的全部都是中转点,再给出 这些点中的m 条边,代表这两点间的最大传输电量,并且给出发电站的最大发送电量 ...

  9. poj 1459 Power Network(增广路)

    题目:http://poj.org/problem?id=1459 题意:有一些发电站,消耗用户和中间线路,求最大流.. 加一个源点,再加一个汇点.. 其实,过程还是不大理解.. #include & ...

随机推荐

  1. Flask 蓝图(Blueprint)

    蓝图使用起来就像应用当中的子应用一样,可以有自己的模板,静态目录,有自己的视图函数和URL规则,蓝图之间互相不影响.但是它们又属于应用中,可以共享应用的配置.对于大型应用来说,我们可以通过添加蓝图来扩 ...

  2. Tornado 网站demo 一

    web服务器的工作过程 创建 listen socket, 在指定的监听端口, 等待客户端请求的到来 listen socket 接受客户端的请求, 得到 client socket, 接下来通过 c ...

  3. surging教学视频资源汇总

    surging是什么 surging 是一个分布式微服务框架,提供高性能RPC远程服务调用,采用Zookeeper.Consul作为surging服务的注册中心,集成了哈希,随机,轮询.压力最小优先作 ...

  4. EasyUI中easyui-combobox的onchange事件。

    html: <select id="cbox" class="easyui-combobox" name="dept" style=& ...

  5. Nokia大事录

    1994年,接通中国第一个GSM电话. 1995年,接通中国第一个无线数据电话. 1996年,接通中国第一个GSM1800网络电话.首家推出同时支持简繁中文短讯的移动电话--诺基亚8110.  199 ...

  6. 关于团购VPS的事情报告

    作者 玄魂   2017-08-11 玄魂工作室-玄魂 玄魂工作室首先要抱歉,之前的说的继续组织大家购买vps的事情,不会再组织了.原因有以下几个:1)因为人多,需求各不相同,不好协调.2)服务都是购 ...

  7. 算法题丨3Sum

    描述 Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find all ...

  8. 解决IE8下opacity属性失效问题

    由于opacity属性存在兼容性问题,所以在IE8下,用opacity来设置元素的透明度,会失效,从而导致页面的样式问题. 在IE8及其更早的浏览器下,我们可以使用filter属性,来代替opacit ...

  9. 你考虑清楚了吗就决定用 Bootstrap ?

    近年来,在前端项目中, Bootstrap 已经成为了一个非常受欢迎的工具. Bootstrap 的确有很多优点,然而,如果你的团队中恰好有一个专职的前端工程师.那我推荐你们不要使用 Bootstra ...

  10. HTTP协议扫盲(五)HTTP请求防篡改

    相关链接: http://www.cnblogs.com/ziyi--caolu/p/4742577.html 请求防重放:http://www.2cto.com/kf/201612/573045.h ...