#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算法模板+最小割性质的更多相关文章

  1. hdu 2435dinic算法模板+最小割性质

    hdu2435最大流最小割 2014-03-22 我来说两句 来源:hdu2435最大流最小割 收藏 我要投稿 2435 There is a war 题意: 给你一个有向图,其中可以有一条边是无敌的 ...

  2. POJ 1815 - Friendship - [拆点最大流求最小点割集][暴力枚举求升序割点] - [Dinic算法模板 - 邻接矩阵型]

    妖怪题目,做到现在:2017/8/19 - 1:41…… 不过想想还是值得的,至少邻接矩阵型的Dinic算法模板get√ 题目链接:http://poj.org/problem?id=1815 Tim ...

  3. POJ 1273 Drainage Ditches(网络流dinic算法模板)

    POJ 1273给出M条边,N个点,求源点1到汇点N的最大流量. 本文主要就是附上dinic的模板,供以后参考. #include <iostream> #include <stdi ...

  4. HDU1532最大流 Edmonds-Karp,Dinic算法 模板

    Drainage Ditches Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...

  5. 洛谷.4897.[模板]最小割树(Dinic)

    题目链接 最小割树模板.具体见:https://www.cnblogs.com/SovietPower/p/9734013.html. ISAP不知为啥T成0分了.. Dinic: //1566ms ...

  6. POJ 3469.Dual Core CPU 最大流dinic算法模板

    Dual Core CPU Time Limit: 15000MS   Memory Limit: 131072K Total Submissions: 24830   Accepted: 10756 ...

  7. POJ 1273 - Drainage Ditches - [最大流模板题] - [EK算法模板][Dinic算法模板 - 邻接表型]

    题目链接:http://poj.org/problem?id=1273 Time Limit: 1000MS Memory Limit: 10000K Description Every time i ...

  8. HDU 3526 Computer Assembling(最小割)

    http://acm.hdu.edu.cn/showproblem.php?pid=3526 题意:有个屌丝要配置电脑,现在有n个配件需要购买,有两家公司出售这n个配件,还有m个条件是如果配件x和配件 ...

  9. [模板]最小割树(Gomory-Hu Tree)(luogu4897)

    给定一个\(n\)个点\(m\)条边的无向连通图,多次询问两点之间的最小割 两点间的最小割是这样定义的:原图的每条边有一个割断它的代价,你需要用最小的代价使得这两个点不连通 Input 第一行两个数\ ...

随机推荐

  1. setOutputFormat called in an invalid state: 1

    在编写一个简单的录像应用程序的时候,爆出例如以下异常: E MediaRecorder: setOutputFormat called in an invalid state: 1 E Android ...

  2. 关于联想超极本出现蓝屏Default Boot Device Missing or Boot Failed的解决办法

    联想笔记本出现以下症状无法开机时: 解决方案:恢复BIOS默认设置,把硬盘设置为第一启动项. 若成功检测到硬盘并有EFI引导程序,那么恭喜你这就完事了,重启后就可以正常开机了. 但是,若在UEFI模式 ...

  3. 深入理解 python 元类

    一.什么的元类 # 思考: # Python 中对象是由实例化类得来的,那么类又是怎么得到的呢? # 疑问: # python 中一切皆对象,那么类是否也是对象?如果是,那么它又是那个类实例化而来的呢 ...

  4. Hadoop MapReduce编程 API入门系列之FOF(Fund of Fund)(二十三)

    不多说,直接上代码. 代码 package zhouls.bigdata.myMapReduce.friend; import org.apache.hadoop.io.Text; public cl ...

  5. Android线程间异步通信机制源码分析

    本文首先从整体架构分析了Android整个线程间消息传递机制,然后从源码角度介绍了各个组件的作用和完成的任务.文中并未对基础概念进行介绍,关于threadLacal和垃圾回收等等机制请自行研究. 基础 ...

  6. 微信小程序开发之animation动画实现

    1. 创建动画实例 wx.createAnimation(OBJECT) 创建一个动画实例animation.调用实例的方法来描述动画.最后通过动画实例的export方法导出动画数据传递给组件的ani ...

  7. readonly and const variable

    共同点:都是常量: 不同点:const的值必须在编译前确定,通常在声明的同时赋值:而readonly可在运行时确定:

  8. RAP开发入门-运行过程简析(三)

    今天通过标准的RAP程序来简单分析下RAP的启动过程 1.新建一个标准的rap plugin-in 项目: 得到的项目结构大概如下: run confi..->..add bundle(配置好b ...

  9. java servlet 3.0文件上传

    在以前,处理文件上传是一个很痛苦的事情,大都借助于开源的上传组件,诸如commons fileupload等.现在好了,很方便,便捷到比那些组件都方便至极.以前的HTML端上传表单不用改变什么,还是一 ...

  10. 文件被占用导致Hive Load文件不成功

    用Python写了个用LOAD命令将文件导入Hive的程序,开始代码写成下面这样: def loadToHive(bakFilePath, tbName): try: transport = TSoc ...