hdu 2435 dinic算法模板+最小割性质
#include<stdio.h>
#include<queue>
#include<string.h>
using namespace std;
#define inf 0x3fffffff
#define N 200
struct node {
int v,w,next;
}bian[N*N*2],fbian[N*N*2];
int head[N],yong,tt;
int deep[N];//深度保留层次图
void addedge(int u,int v,int w) {
bian[yong].v=v;
bian[yong].w=w;
bian[yong].next=head[u];
head[u]=yong++;
}
int bfs(int s) {//寻找层次图
int i,cur;
queue<int>q;
memset(deep,-1,sizeof(deep));
q.push(s);
deep[s]=1;
while(!q.empty()) {
cur=q.front();
q.pop();
for(i=head[cur];i!=-1;i=bian[i].next)
if(bian[i].w&&deep[bian[i].v]==-1) {
deep[bian[i].v]=deep[cur]+1;
q.push(bian[i].v);
}
}
if(deep[tt]!=-1)return 1;
return 0;
}
int Min(int a,int b) {
return a>b?b:a;
}
int dfs(int s,int limit) {//多次dfs
int i,cost=0,flow,v;
// printf("%d %d\n",s,head[s]);
if(s==tt) {return limit;}
for(i=head[s];i!=-1;i=bian[i].next) {
v=bian[i].v;
// printf("%d %d %d\n",s,v,bian[i].w);
if(bian[i].w&&deep[v]==deep[s]+1) {
// printf("%d\n",v);
flow=dfs(v,Min(limit-cost,bian[i].w));
if(flow>0) {
bian[i].w-=flow;
bian[i^1].w+=flow;
cost+=flow;
if(limit==cost)break;
}
else
deep[v]=-1;//如果再次遇到v就不会进行下去
}
}
return cost ;
}
int dinic_maxflow(int s) {//dinic算法模板
int sum=0;
while(bfs(1)) {
//for(i=1;i<=tt;i++)
// printf("%d\n",deep[i]);
sum+=dfs(1,inf);
}
return sum;
}
/*int visit[N];
void dfs1(int u) {
int i;
visit[u]=1;
for(i=head[u];i!=-1;i=bian[i].next) {
if(bian[i].w&&visit[bian[i].v]==0)
dfs1(bian[i].v);
}
}*/
int ds[N],dds,dt[N],ddt;
int fhead[N],fyong;
int main() {
int t,m,n,i,j,k,maxflow,ma,fma,fa,fb;
scanf("%d",&t);
while(t--) {
scanf("%d%d",&n,&m);
yong=0;
memset(head,-1,sizeof(head));
while(m--) {
scanf("%d%d%d",&i,&j,&k);
addedge(i,j,k);//加入边
addedge(j,i,0);//退边
}
tt=n;
maxflow=dinic_maxflow(1);//最大流模板
dds=0;ddt=0;
/* memset(visit,0,sizeof(visit));
dfs1(1);*/
for(i=2;i<n;i++) {//根据deep是否为-1可以得到源点集和汇点集
if(deep[i]!=-1)//源点集
ds[++dds]=i;
else
dt[++ddt]=i;//汇点集
}
// printf("%d %d\n",dds,ddt);
/* for(i=2;i<n;i++) {
if(visit[i])
ds[++dds]=i;
else
dt[++ddt]=i;
}*/
for(i=0;i<yong;i++)//保留残留网络
fbian[i]=bian[i];
for(i=1;i<=n;i++)//保留残留网络
fhead[i]=head[i];
ma=0;
fyong=yong;//保留残留网络
for(i=1;i<=dds;i++)//枚举
for(j=1;j<=ddt;j++) {
fa=ds[i];fb=dt[j];
for(k=0;k<yong;k++)//加入了新边,必须跟新为原来的求最大流一次的残留网络
bian[k]=fbian[k];
memset(head,0,sizeof(head));
for(k=1;k<=n;k++) //因为加入了新边,所以必须跟新head的值为原来的残留网络
head[k]=fhead[k];
yong=fyong;//
addedge(fa,fb,inf);
addedge(fb,fa,0);
fma=dinic_maxflow(1);
if(fma>ma)//求出最大值
ma=fma;
}
printf("%d\n",ma+maxflow);
}
return 0;
}
hdu 2435 dinic算法模板+最小割性质的更多相关文章
- hdu 2435dinic算法模板+最小割性质
hdu2435最大流最小割 2014-03-22 我来说两句 来源:hdu2435最大流最小割 收藏 我要投稿 2435 There is a war 题意: 给你一个有向图,其中可以有一条边是无敌的 ...
- POJ 1815 - Friendship - [拆点最大流求最小点割集][暴力枚举求升序割点] - [Dinic算法模板 - 邻接矩阵型]
妖怪题目,做到现在:2017/8/19 - 1:41…… 不过想想还是值得的,至少邻接矩阵型的Dinic算法模板get√ 题目链接:http://poj.org/problem?id=1815 Tim ...
- POJ 1273 Drainage Ditches(网络流dinic算法模板)
POJ 1273给出M条边,N个点,求源点1到汇点N的最大流量. 本文主要就是附上dinic的模板,供以后参考. #include <iostream> #include <stdi ...
- HDU1532最大流 Edmonds-Karp,Dinic算法 模板
Drainage Ditches Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...
- 洛谷.4897.[模板]最小割树(Dinic)
题目链接 最小割树模板.具体见:https://www.cnblogs.com/SovietPower/p/9734013.html. ISAP不知为啥T成0分了.. Dinic: //1566ms ...
- POJ 3469.Dual Core CPU 最大流dinic算法模板
Dual Core CPU Time Limit: 15000MS Memory Limit: 131072K Total Submissions: 24830 Accepted: 10756 ...
- POJ 1273 - Drainage Ditches - [最大流模板题] - [EK算法模板][Dinic算法模板 - 邻接表型]
题目链接:http://poj.org/problem?id=1273 Time Limit: 1000MS Memory Limit: 10000K Description Every time i ...
- HDU 3526 Computer Assembling(最小割)
http://acm.hdu.edu.cn/showproblem.php?pid=3526 题意:有个屌丝要配置电脑,现在有n个配件需要购买,有两家公司出售这n个配件,还有m个条件是如果配件x和配件 ...
- [模板]最小割树(Gomory-Hu Tree)(luogu4897)
给定一个\(n\)个点\(m\)条边的无向连通图,多次询问两点之间的最小割 两点间的最小割是这样定义的:原图的每条边有一个割断它的代价,你需要用最小的代价使得这两个点不连通 Input 第一行两个数\ ...
随机推荐
- 状态压缩dp poj 3254 hdu5045
近来感觉状态压缩dp的强大性(灵活利用了二进制运算非常关键). . . 于是做了俩提来看看..毕竟队友是专业的dp.我仅仅是管中窥豹下而已.. 日后有机会再与之玩耍玩耍...ps:假设上天再给我一次机 ...
- Linux命令(十一)——Shell程序设计二(循环控制语句)
1.if语句 (1)两路分支的if语句 (2)多路条件判断分支的if语句 2.测试语句 (1)文件测试 (2)字符串测试 (3)数值测试 (4)用逻辑操作符进行组合的测试语句 3.case语句 4.f ...
- [Linux]history 显示命令执行的时间
显示历史命令之行时间 这里的环境是centos5.8 vim ~/.bashrc 或者 ~/.bash_profile 增加 export HISTTIMEFORMAT="%F %T & ...
- Dark roads--hdoj
Dark roads Time Limit : 2000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) Total Su ...
- cxf调用WebService
一.用CXF调用WebService的几种方式,参考: http://cxf.apache.org/docs/how-do-i-develop-a-client.html 二.JaxWsProxyFa ...
- NAS与SAN有什么区别?
NAS和SAN字面上相似,并且都是新型数据存储模式,但这二者是完全不同的,针对不同方向的技术,为了能够更好的区分它们,天伟数据恢复整理了以下内容供读者参考(天伟数据恢复建议重要数据多备份,备份很重要以 ...
- js设计模式-门面模式
适用场景:门面模式在DOM脚本编程这种需要对各种不一致的浏览器接口的环境中很常用. 例子:阻止模式事件 var DED = widow.DED || {}; DED.util = { stopProp ...
- 24. Swap Nodes in Pairs[M]两两交换链表中的节点
题目 Given a linked list, swap every two adjacent nodes and return its head. You may not modify the va ...
- python 飞机大战 实例
飞机大战 #coding=utf-8 import pygame from pygame.locals import * import time import random class Base(ob ...
- 字符串比较——compareTo函数
package com.day03.ifelse; import java.math.BigInteger; /** * @author 王恒 * @datetime 2017年4月7日 下午3:13 ...