求最小割的问题。

题意:已知网络中有n个源点,m的中转站(也就是节点),一个汇点(编号为0)。给出网络,求一些边(增大这个边就可以增大汇点流量的边)。

思路:一开始代码只找了有流=0就加入输出数组的情况,然而忽略了流向一条S->T的流有多个边权=0的情况,此时只增大一条边的值是没用的。

所以除了用一次最大流算法后,还需要用两次dfs分别从超级源点S和汇点T开始搜索,这样就可以把有多个0-0-0和单个边权为0的情况判断出来。

 #include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <vector>
#include <algorithm>
using namespace std;
const int INF = 0x3f3f3f3f;
typedef struct node
{
int u;
int v;
int Flow;
int next;
}Line;
Line Li[];
int Head[],top;
int vis[],ans[];
bool vis1[],vis2[];
int n,m,l;
int s,t;
void AddEdge(int u,int v,int f)
{
Li[top].v=v; Li[top].u=u;
Li[top].Flow=f;
Li[top].next=Head[u];
Head[u]=top++;
}
bool BFS()
{
memset(vis,-,sizeof(vis));
vis[s]=;
queue<int >Q;
Q.push(s);
while(!Q.empty())
{
int u=Q.front();
Q.pop();
for(int i=Head[u];i!=-;i=Li[i].next)
{
if(Li[i].Flow&&vis[Li[i].v]==-)
{
vis[Li[i].v]=vis[u]+;
Q.push(Li[i].v);
}
}
}
return vis[t]!=-;
}
int DFS(int u,int f)
{
if(u==t)
{
return f;
}
int ans=;
for(int i=Head[u];i!=-;i=Li[i].next)
{
if(Li[i].Flow&&vis[Li[i].v]==vis[u]+)
{
int d=DFS(Li[i].v,min(f,Li[i].Flow));
f-=d;
Li[i].Flow-=d;
Li[i^].Flow+=d;
ans+=d;
}
}
return ans;
}
void dfs(int u,bool *vist,int op)
{
vist[u]=true;
for(int i=Head[u];i!=-;i=Li[i].next)
{
if(!vist[Li[i].v]&&Li[i^op].Flow!=)
{
dfs(Li[i].v,vist,op);
}
}
}
void Dinic()//网络流进行增广
{
int ans;
while(BFS())
{
ans=DFS(s,INF);
printf("!\n");
}
}
int main()
{
while(~scanf("%d %d %d",&n,&m,&l))
{
if(n+m+l==)
{
break;
}
s=n+m+;//源点
t=;//汇点
memset(Head,-,sizeof(Head));
int a,b,c;
top = ;
for(int i=;i<l;i++)
{
scanf("%d %d %d",&a,&b,&c);
AddEdge(a,b,c);//建立边,正向为c,负向为0
AddEdge(b,a,);
}
for(int i=;i<=n;i++)
{
AddEdge(s,i,INF);
AddEdge(i,s,);//建立城市与源点之间的边,权值为INF
}
Dinic();
memset(vis1,false,sizeof(vis1));
memset(vis2,false,sizeof(vis2));
dfs(s,vis1,);//从源点向汇点搜索,标记还有剩余流的点
dfs(t,vis2,);//从汇点到源点搜索,标记还有剩余流的点
int num=;
for(int i=;i<l;i++)
{
if(Li[i<<].Flow==&&vis1[Li[i<<].u]&&vis2[Li[i<<].v])
ans[num++]=i+;//如果一条边的u与v都被标记,表明s->u,v->t,但是这条边是满流,所以提升这条边。
}
if(num)
{
for(int i=;i<num;i++)
{
if(i)printf(" ");
printf("%d",ans[i]);
}
}
printf("\n");
}
return ;
}

代码转自(https://blog.csdn.net/huayunhualuo/article/details/50554800)这个题解的板子跟我的差不多就转了

ZOJ 2532 网络流最小割的更多相关文章

  1. 【题解】 bzoj3894: 文理分科 (网络流/最小割)

    bzoj3894,懒得复制题面,戳我戳我 Solution: 首先这是一个网络流,应该还比较好想,主要就是考虑建图了. 我们来分析下题面,因为一个人要么选文科要么选理科,相当于两条流里面割掉一条(怎么 ...

  2. 【bzoj3774】最优选择 网络流最小割

    题目描述 小N手上有一个N*M的方格图,控制某一个点要付出Aij的代价,然后某个点如果被控制了,或者他周围的所有点(上下左右)都被控制了,那么他就算是被选择了的.一个点如果被选择了,那么可以得到Bij ...

  3. 【bzoj1143】[CTSC2008]祭祀river Floyd+网络流最小割

    题目描述 在遥远的东方,有一个神秘的民族,自称Y族.他们世代居住在水面上,奉龙王为神.每逢重大庆典, Y族都会在水面上举办盛大的祭祀活动.我们可以把Y族居住地水系看成一个由岔口和河道组成的网络.每条河 ...

  4. 【bzoj1797】[Ahoi2009]Mincut 最小割 网络流最小割+Tarjan

    题目描述 给定一张图,对于每一条边询问:(1)是否存在割断该边的s-t最小割 (2)是否所有s-t最小割都割断该边 输入 第一行有4个正整数,依次为N,M,s和t.第2行到第(M+1)行每行3个正 整 ...

  5. 【bzoj1976】[BeiJing2010组队]能量魔方 Cube 网络流最小割

    题目描述 一个n*n*n的立方体,每个位置为0或1.有些位置已经确定,还有一些需要待填入.问最后可以得到的 相邻且填入的数不同的点对 的数目最大. 输入 第一行包含一个数N,表示魔方的大小. 接下来 ...

  6. 【bzoj4177】Mike的农场 网络流最小割

    题目描述 Mike有一个农场,这个农场n个牲畜围栏,现在他想在每个牲畜围栏中养一只动物,每只动物可以是牛或羊,并且每个牲畜围栏中的饲养条件都不同,其中第i个牲畜围栏中的动物长大后,每只牛可以卖a[i] ...

  7. 【bzoj3438】小M的作物 网络流最小割

    原文地址:http://www.cnblogs.com/GXZlegend/p/6801522.html 题目描述 小M在MC里开辟了两块巨大的耕地A和B(你可以认为容量是无穷),现在,小P有n中作物 ...

  8. 【bzoj3144】[Hnoi2013]切糕 网络流最小割

    题目描述 输入 第一行是三个正整数P,Q,R,表示切糕的长P. 宽Q.高R.第二行有一个非负整数D,表示光滑性要求.接下来是R个P行Q列的矩阵,第z个 矩阵的第x行第y列是v(x,y,z) (1≤x≤ ...

  9. 【bzoj3894】文理分科 网络流最小割

    原文地址:http://www.cnblogs.com/GXZlegend 题目描述 文理分科是一件很纠结的事情!(虽然看到这个题目的人肯定都没有纠结过) 小P所在的班级要进行文理分科.他的班级可以用 ...

随机推荐

  1. python装饰器的参数传递

    被装饰器装饰的函数名即使没有被调用(因为有@xxx,会触发运行装饰器),(装饰器工厂函数)定义装饰器的代码已经运行了(最内部的那个函数并没有运行)(把被装饰的原函数引用赋值给了装饰器内部的那个函数名) ...

  2. 内存管理-MRC

    MRC内存管理 环境:先关闭arc模式,选中项目->build Settings

  3. 并发与高并发(三)-CPU多级缓存の乱序执行优化

    一.CPU多级缓存-乱序执行优化 处理器或编译器为提高运算速度而做出违背代码原有顺序的优化. 重排序遵循原则as-if-serial as-if-serial语义:不管怎么重排序(编译器和处理器为了提 ...

  4. BBS数据库设计

    BBS数据库设计 一.BBS数据库设计 # models.py from django.db import models # Create your models here. from django. ...

  5. js 选中div中的文本

    function selectText(element) { var text = document.getElementById(element); if (document.body.create ...

  6. UVa202

    刚刚开始写的适合感觉是转换成字符然后开始遍历一遍,后面发现各种不行,就回去看了看题目,重新构思,写了好久还是WA,最后只能看下大神的操作(我太菜了). 先简单梳理下题目意思:首先给出两个数,然后这两个 ...

  7. 安装 texlive

    多系统使用texlive 中文latex 用xelatex 编译 只需要加入宏包 \usepackage[UTF8]{ctex} Rmarkdown 配置模版 $ cat _output.yaml b ...

  8. Tidb go mac 上开发环境搭建

    1.安装golang 运行环境 2.安装lite ide 工具 3.安装dep 包管理工具 4.安装delve debuger 调试工具 我用的是mac hight sierra 10.13 版, 会 ...

  9. 用冒泡法对5个Date类型的数据进行排序

    import java.util.*; public class OrderDate{ public static void main(String[] args){ Date[] days = ne ...

  10. Codeforces Round #579 (Div. 3) Complete the Projects(贪心、DP)

    http://codeforces.com/contest/1203/problem/F1 Examples input 1 - - output 1 YES input 2 - - output 2 ...