Mike的农场

4 篇文章 0 订阅
2 篇文章 0 订阅

题目

Mike有一个农场,这个农场n个牲畜围栏,现在他想在每个牲畜围栏中养一只动物,每只动物可以是牛或羊,并且每个牲畜围栏中的饲养条件都不同,其中第i个牲畜围栏中的动物长大后,每只牛可以卖a[i]元,每只羊可以卖b[i]元,为了防止牛羊之间相互影响,Mike找到了m条规律,每条规律给出一个三元组(i, j, k)表示如果第i个围栏和第j个围栏养的是不同的动物,那么Mike就需要花费k的代价请人帮忙处理牛羊之间的影响。不过同时Mike也发现k条特殊的规则(S, a, b),表示如果S中所有牲畜围栏中都养的是动物a,那么Mike可以获得b的额外收入。
现在Mike想知道他该在哪些围栏中饲养什么动物才能使得总收益最大,为了简化问题,你只需要输出最大收益。

分析

这道题用到最小割算法。
我们定义 s t为源点和汇点。
对于每个点 i ,从s i 连一条容量为a[i]的边,从 i t连一条容量为 b[i] 的边。
对于每个规律 (i,j,k) i j连一条容量为 k 的边,j i 连一条容量为k的边。
对于每个规则 (S,a,b) ,先建立一个新的点 e ,分两种情况:
如果a=0,从s e 连一条容量为b的边,再从 e S集合中的每一个点连一条容量为 的边。
如果a=1,从e t 连一条容量为b的边,再从 S 集合中的每一个点向e连一条容量为 <script type="math/tex" id="MathJax-Element-30">∞</script>的边。
ok了。
网络流,
dinic会超时,用SAP+GAP

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值