网络流
文章平均质量分 76
AcDora
这个作者很懒,什么都没留下…
展开
-
UVa10779 Collectors' Problem( 网络流,建图)
这是一道建图的题,只要能想清楚怎么建图,就没有问题建图:Bob和所有粘贴相连,边的容量是他所拥有粘贴的个数; 其他人和他们所拥有的粘贴相连,边容量为手中物品个数减1,因为他们要保留一个 其他人没有的粘贴,从粘贴连到这个人,容量为1,他只能接受一个这种粘贴 每种粘贴和汇点相连,容量为1代码如下:#include原创 2013-02-03 15:32:46 · 744 阅读 · 0 评论 -
poj 3281 dining( 最大流 )
这里很显然是拆点。但是在呢么拆呢之前做的时候,是拆的牛,今天拆的食物和水,果断错了,按照我的建图方法,S连牛,牛连水,水连食物,食物连E,很显然,无法保证从牛出的到水,然后从水走出的边无法保证是之前那个牛喜欢的食物,因此错!正常的建图,S连水,水连牛,牛拆点,牛连食物,食物连E!细节见代码:#include #include int N, F, D, map[500][500原创 2013-08-02 20:17:51 · 778 阅读 · 0 评论 -
POJ 1966 Cable TV Network (用最大流求最小割点数量)
这道题,要注意,写网络流的时候,最好最好不要破坏原来的矩阵,尤其是需要多次求一个图的最大流的时候。这道题,是求一个图的最小割点数。开始以为有专门的算法可以用呢,不过没有找到,然后想拆点求最小割,但是不知道无向图应该怎么建,如果正常拆点的话,拆出来的图还是一个有向图,SW只是解决无向图的情况,很纠结!要是哪位大牛路过知道有更好的算法的话,跪求指点!这道题的做法就是,拆点,将每个点拆为入点和出原创 2013-05-01 11:37:49 · 1266 阅读 · 0 评论 -
HEU Mining Station on the Sea(最小费用最大流)
常规题目;最小费用最大流,如果是无向图的话,一定用邻接表去做。代码://最小费用最大流,注意建图的edge都是双向的#include #include #include #include using namespace std;const int INF = 0x3fffffff;const int N = 350;int S = 0, E;int n, m, k,原创 2013-04-26 21:08:21 · 1102 阅读 · 0 评论 -
UVa 10480 Sabotage ( 最小割最大流定理)
这是一道很典型的最小割最大流定理,通过这道题,我再一次学习了最小割的定义最小割,就是在所有割中,容量之和最小的割,这就是我的理解,而最小割的值就是最大流的值,因为很容易想到,从源点s到汇点t的最大流必然会经过割边,那么就有最大流f第二点,怎么求出最小割的边:在求出最大流之后,残余网络会分成两个部分,和源点相连的是一个集合,和汇点相连的是另一个集合,然后用a表示从源点到其他各点的最大流,在求原创 2013-02-28 10:21:08 · 2671 阅读 · 0 评论 -
UVa 563 Crimewave ( 用最大流判断,拆点)
这道题主要思想就是建图,拆点,判断判断最大流是不是等于银行个数拆点,每个点只能经过一次,有容量的点都拆成进点和出点,从进点进,从出点出建图,将所有的点重新编号,bank和的进点和源点相连,容量为1;grid的四框上的点的拆出来的点和汇点相连,容量INF;每个点对应的进入点和出点容量为1;每个点的出点和上下左右的点的进点相连,容量为1代码:#include #inclu原创 2013-02-28 11:42:52 · 836 阅读 · 0 评论 -
UVa10594 Data Flow(最小费用 最大流)
这道题是一道最小费用最大流问题,从这道题里面,我更加理解什么是最小费用最大流了,主要就是在找最短路径的同时,还要顾及到最大流量及残余网络,其实就是在残余网络中找最短路径有一下要注意的:第一,边的两个方向,费用互为相反数第二,无向图的最小费用最大流,要用邻接表表示,因为点和点之间的两个方向的边要分别表示其反方向,也就是这两边是独立的,不能用互为反边的思想,否则会出现环路,而且会无限循环,原创 2013-02-27 12:56:29 · 965 阅读 · 1 评论 -
Uva 11506 Angry Programmer ( 最小割最大流,拆点,建图)
这个道题,第一次邻接表写的,wa了,然后换的矩阵,结果还是不对,但是发现哪里错了主要是建图,判断两个点是不是起点或者汇点,对这两个点,就不要拆了,因为没有费用其余的所有的点,都用拆成两个点,然后容量为这个computer的费用,其他的就按照规则,从原始点进,从拆出的点出矩阵的代码如下:#include #include #include #include using nam原创 2013-03-06 18:44:29 · 1819 阅读 · 0 评论 -
UVa 10746 Crime Wava-The Sequel (最小费用最大流 + 精度)
这道题我提交很多次,多事submission error 后来重新写了,就好了,总结一下,submission error 还是说明代码有问题,这次我开始的时候没有考虑到精度问题,而且数组也开得很小做题的时候,切忌心烦意乱,要平稳一些, 仔细一些,对于最大流的问题,要注意到点的数量,和标号,这个千万不要错还有,最小费用最大流,一定要给每条边的反向边也赋初值,互为反向边的权值是互为倒数代原创 2013-03-05 19:33:25 · 1666 阅读 · 0 评论 -
UVa 259 Software Allocation ( 最大流 )
这道题也是,输入很坑,每组之间也空格结束,最后以EOF结束建图其实有一种比这个好的方法,不用拆点,就是源点和computer相连,容量1, computer和program连,容量1, program和汇点连,容量为相应数字但是一下代码,是拆点做的,把computer拆了,因为computer的容量为1,下面代码也是对照这个建图方法建的,program和源点连,容量为相应数字,和compu原创 2013-03-03 17:17:10 · 2364 阅读 · 0 评论 -
UVa 820 Internet Bandwidth (最大流模板题)
这道题要注意一下几个问题:第一、所有的路都是双向,也两个方向上的流量相等第二、刚开始写模板的时候,写错了,但是原因我还没有想得很清楚总之代码如下:#include #include #include #include using namespace std;const int N = 110;const int INF = 10000;int S, T, M, n,原创 2013-02-17 13:44:36 · 1609 阅读 · 2 评论 -
La (NWERC2007 Problem B )- March of the Penguins(最大流 拆点)
这道题终于又了结果,哈哈,真开心!其实这题不难,就是有点麻烦题意:有n个点,每个点上有ni只企鹅,每个点只能允许mi只企鹅跳离这个点;并且每只企鹅,一次最多能跳D这么长的距离;目的是让左右企鹅能在一个点聚会,那么问,哪些点能作为聚会的点,一次输出这些点,如果没有方案那么就是输出-1。(n分析:让所有企鹅在同一点聚会,那么显然是看流入是否等于流出,最大流问题;每个点有流量mi,显原创 2013-02-14 18:53:41 · 1134 阅读 · 2 评论 -
UVa11045 My T-shirt suits me( 最大流 )
这是很简单的最大流的题目,问题的重点在于如何建图题目大意:分配衬衫,将这些衬衫分给志愿者,每个志愿可以接受两种size,每种衣服的数量相同,每种衣服都有一手号(即从XS到XXL六个码)求是否存在这样的分配那么设0为原点,m+7为汇点,将六个型号分别设点然后从原点到型号点的容量设为其数量(看题就知道了,数量很好求),从型号到每个志愿者连起来,容量为1,志愿者只需要一件衣服,从志愿者到原创 2013-02-04 22:31:23 · 1054 阅读 · 0 评论 -
UVa10330 Power Transmission (最大流,拆点)
开始没有注意每个regulator都有一个限制,wa了改的时候也没有反应过来这个问题,直接在边上做的文章,显然不对之后好好想想,一个点可以接受的power很可能是从很多条边流过来的,所以想到,这个点是有流量的,所以拆点经验:如果每条边有流量限制的话,那么就拆点;仔细读题,挖掘隐含的点流量的条件代码如下:#include #include #include #include原创 2013-02-03 16:48:37 · 697 阅读 · 0 评论 -
hdu 3046 Pleasant sheep and big big wolf(sap最大流)
开始在hrbust上做的,数据改为20,用矩阵和普通的最大流算法均可以过!后来查的时候看到了hdu上的,数据比那个大很多,点数最多可达40000,第一次MLE,换成邻接表,第二次TLE,果断换算法,sap轻松秒过!建图的方法就是远点连2, 终点连1,容量inf, 把每个挨着的格子连起来,容量1,求最小割! 这里求最小割很好理解,就像从一个2开始走,向1走,然后每次走都会经过一个格子的边界,一般原创 2013-08-02 22:20:03 · 852 阅读 · 0 评论