一道裸的最小割的题,写一下只是练练手。

表示被卡M,RE不开心。一道裸题至于吗?

再次复习一下最大权闭合子图:

1.每一个点若为正权,与源点连一条容量为绝对值权值的边。否则连向汇点一条容量为绝对值权值的边

2.如果有选了A点才能选B点的约束条件,且违背这个约束条件有C的代价,则从A点向B点连一条容量为C的边(如果不能违背,则连一条容量为INF的边)

3.设源点出度为C,最大流的值为D。答案为C-D。

#include<cstdio>
#include<queue>
#include<algorithm>
using namespace std ; namespace DINIC { const int MAXVn = * + ;
const int MAXEn = * + ;
int Vn ; struct edge {
int p ;
int c ;
edge * nxt ;
edge * brother ;
} ; edge E [ MAXEn * ] ;
namespace E_SET { edge * T = E ; } ;
edge * V [ MAXVn ] ; int S , T ; void add_edge ( const int a , const int b , const int f ) {
using E_SET :: T ;
T -> p = b ; T -> c = f ; T -> nxt = V [ a ] ; V [ a ] = T ++ ;
T -> p = a ; T -> c = ; T -> nxt = V [ b ] ; V [ b ] = T ++ ;
V [ a ] -> brother = V [ b ] ; V [ b ] -> brother = V [ a ] ;
} edge * cur [ MAXVn ] ;
int dis [ MAXVn ] ; bool bfs ( ) {
queue < int > q ;
fill ( dis , dis + Vn , - ) ;
copy ( V , V + Vn , cur ) ;
q . push ( S ) ; dis [ S ] = ;
while ( ! q . empty () ) {
const int o = q . front () ; q . pop () ;
for ( edge * v = V [ o ] ; v != ; v = v -> nxt )
if ( v -> c != && dis [ v -> p ] == - ) {
dis [ v -> p ] = dis [ o ] + ;
q . push ( v -> p ) ;
}
}
return dis [ T ] != - ;
} int dfs ( const int o , int flow ) {
if ( o == T || flow == ) return flow ;
int f , ans = ;
for ( edge * & v = cur [ o ] ; v != ; v = v -> nxt )
if ( dis [ o ] + == dis [ v -> p ] &&
( f = dfs ( v -> p , min ( flow , v -> c ) ) ) != ) {
v -> c -= f ; v -> brother -> c += f ;
ans += f ; flow -= f ;
if ( flow == ) break ;
}
return ans ;
} int dinic ( ) {
int ans = ;
while ( bfs ( ) ) ans += dfs ( S , << ) ;
return ans ;
} } int M , N ;
int sum ; int main () { using namespace DINIC ;
scanf ( "%d%d" , & N , & M ) ;
Vn = M + N + ; //in && out && S && T
S = ;
T = ; #define WORK(a) ((a)+2)
#define MACHINE(a) ((a)+N+2) for ( int i = ; i < N ; ++ i ) {
int value_of_w , num_of_w ; scanf ( "%d%d" , & value_of_w , & num_of_w ) ;
sum += value_of_w ;
add_edge ( S , WORK(i) , value_of_w ) ;
while ( num_of_w -- ) {
int n , pay ;
scanf ( "%d%d" , & n , & pay ) ;
n -= ;
add_edge ( WORK(i) , MACHINE(n) , pay ) ;
}
}
for ( int i = ; i < M ; ++ i ) {
int pay ; scanf ( "%d" , & pay ) ;
add_edge ( MACHINE(i) , T , pay ) ;
} #undef WORK
#undef MACHINE printf ( "%d\n" , sum - dinic () ) ; return ; }

bzoj1391 最大权闭合子图(also最小割、网络流)的更多相关文章

  1. 【BZOJ】1497: [NOI2006]最大获利 最大权闭合子图或最小割

    [题意]给定n个点,点权为pi.m条边,边权为ci.选择一个点集的收益是在[点集中的边权和]-[点集点权和],求最大获利.n<=5000,m<=50000,0<=ci,pi<= ...

  2. LuoguP2762 太空飞行计划问题(最大权闭合子图,最小割)

    题目描述 W 教授正在为国家航天中心计划一系列的太空飞行.每次太空飞行可进行一系列商业性实验而获取利润.现已确定了一个可供选择的实验集合E={E1,E2,…,Em},和进行这些实验需要使用的全部仪器的 ...

  3. Petya and Graph/最大权闭合子图、最小割

    原题地址:https://codeforces.com/contest/1082/problem/G G. Petya and Graph time limit per test 2 seconds ...

  4. HDU 3917 最大权闭合图 求最小割

    具体参考http://blog.csdn.net/power721/article/details/6665750 TODO //#pragma comment(linker, "/STAC ...

  5. Less Time, More profit 最大权闭合子图(最大流最小割)

    The city planners plan to build N plants in the city which has M shops. Each shop needs products fro ...

  6. BZOJ 4873 [Shoi2017]寿司餐厅 | 网络流 最大权闭合子图

    链接 BZOJ 4873 题解 当年的省选题--还记得蒟蒻的我Day1 20分滚粗-- 这道题是个最大权闭合子图的套路题.严重怀疑出题人就是先画好了图然后照着图编了个3000字的题面.和我喜欢的妹子当 ...

  7. 【POJ 2987】Firing (最小割-最大权闭合子图)

    裁员 [问题描述] 在一个公司里,老板发现,手下的员工很多都不务正业,真正干事员工的没几个,于是老板决定大裁员,每开除一个人,同时要将其下属一并开除,如果该下属还有下属,照斩不误.给出每个人的贡献值和 ...

  8. BZOJ 1565 NOI2009 植物大战僵尸 topo+最小割(最大权闭合子图)

    题目链接:https://www.luogu.org/problemnew/show/P2805(bzoj那个实在是有点小小的辣眼睛...我就把洛谷的丢出来吧...) 题意概述:给出一张有向图,这张有 ...

  9. 洛谷 P4174 [NOI2006]最大获利 && 洛谷 P2762 太空飞行计划问题 (最大权闭合子图 && 最小割输出任意一组方案)

    https://www.luogu.org/problemnew/show/P4174 最大权闭合子图的模板 每个通讯站建一个点,点权为-Pi:每个用户建一个点,点权为Ci,分别向Ai和Bi对应的点连 ...

随机推荐

  1. swift:入门知识之函数与闭包

    1.swift中使用关键字func来声明和定义一个函数.调用函数使用它的名字加上小括号中的参数列表. 2.swift使用->方向符号分隔参数的名字和返回值类型 3.swift使用元组(tuple ...

  2. MimeTypes list

    application/acad *.dwg AutoCAD-Dateien (nach NCSA) application/applefile AppleFile-Dateien applicati ...

  3. 转:java中scanner类的用法

    声明:本文转自百度经验:http://jingyan.baidu.com/article/e73e26c0c74a1f24adb6a7fb.html Scanner是SDK1.5新增的一个类,可是使用 ...

  4. 【笨嘴拙舌WINDOWS】窗体样式

    "眼睛是人类心灵的窗口,打开窗口,你就能看到整个世界" 在PC时代,计算机的显示屏就是真个世界,WINDOWS将真个世界分解为一个个的窗口,每个窗口有自己的容貌,下面我们将一一揭开 ...

  5. POJ 3468 A Simple Problem with Integers

    线段树的指针表示法. 代码还有待消化.. 代码里面多次用到了函数递归,感觉这次对递归又有了深一层的理解. #define LOCAL #include <iostream> #includ ...

  6. hdu 4622 Reincarnation trie树+树状数组/dp

    题意:给你一个字符串和m个询问,问你l,r这个区间内出现过多少字串. 连接:http://acm.hdu.edu.cn/showproblem.php?pid=4622 网上也有用后缀数组搞得. 思路 ...

  7. MKNetworkKit: 网络处理又一利器

    没有认识MK之前,即便ASI已经不再更新,也没有启用ASI.因为ASI对于网络的处理更偏向于底层,适合针对各种情形的扩展. 但是,今天我要开始使用 MKNetworkKit了,项目在github上,使 ...

  8. HDU 1015 Safecracker

    解题思路:这题相当诡异,样例没过,交了,A了,呵呵,因为理论上是可以通过的,所以 我交了一发,然后就神奇的过了.首先要看懂题目. #include<cstdio> #include< ...

  9. XE7 - 程序图标及启动画面图片的注意事项

    还是继续昨晚写的,年前已经解决了这个问题,现在补记下.启动画面失真是本篇笔记的重点.搜索了很多文章,基本上大同小异,几乎都没怎么提及启动画面失真的问题.不知道是不是我的操作不对头,. Project ...

  10. Heritrix源码分析(二) 配置文件order.xml介绍(转)

    本博客属原创文章,欢迎转载!转载请务必注明出处:http://guoyunsky.iteye.com/blog/613412      本博客已迁移到本人独立博客: http://www.yun5u. ...