bzoj 2406 二分+有源有汇上下界网络流可行流判定
弱爆了,典型的行列建模方式,居然想不到,题做少了,总结少了。。。。。。
二分答案mid
s----------------------->i行----------------------->j列----------------------------->t
[si-mid,si+mid] [L,R] [s[j]-mid,s[j]+mid]
即对每一行建一个点,每一列建一个点,用边来表示某一行某一列上的东西.
这种建模方式一般要整体考虑行或列的某些信息.
/**************************************************************
Problem: 2406
User: idy002
Language: C++
Result: Accepted
Time:396 ms
Memory:4576 kb
****************************************************************/ #include <cstdio>
#include <cstring>
#define min(a,b) ((a)<(b)?(a):(b))
#define oo 0x3f3f3f3f
#define N 510
#define S 100010 struct Dinic {
int n, src, dst;
int head[N], dest[S], flow[S], next[S], etot;
int dep[N], cur[N], qu[N], bg, ed; void init( int n, int src, int dst ) {
memset( head, -, sizeof(head) );
etot = ;
this->n = n;
this->src = src;
this->dst = dst;
}
void adde( int u, int v, int f ) {
// fprintf( stderr, "Dinic::adde( %d %d %d )\n", u, v, f );
next[etot]=head[u]; flow[etot]=f; dest[etot]=v; head[u]=etot++;
next[etot]=head[v]; flow[etot]=; dest[etot]=u; head[v]=etot++;
}
bool bfs() {
memset( dep, , sizeof(dep) );
qu[bg=ed=] = src;
dep[src] = ;
while( bg<=ed ) {
int u=qu[bg++];
for( int t=head[u]; ~t; t=next[t] ) {
int v=dest[t], f=flow[t];
if( f && !dep[v] ) {
dep[v] = dep[u]+;
qu[++ed] = v;
}
}
}
return dep[dst];
}
int dfs( int u, int a ) {
if( u==dst || a== ) return a;
int remain=a, past=, na;
for( int &t=cur[u]; ~t; t=next[t] ) {
int v=dest[t], &f=flow[t], &vf=flow[t^];
if( f && dep[v]==dep[u]+ && (na=dfs(v,min(remain,f))) ) {
f -= na;
vf += na;
remain -= na;
past += na;
if( !remain ) break;
}
}
return past;
}
int maxflow() {
int f = ;
while( bfs() ) {
for( int u=; u<=n; u++ ) cur[u]=head[u];
f += dfs( src, oo );
}
// fprintf( stderr, "maxflow() = %d\n", f );
return f;
}
};
struct TopBot {
int n;
int head[N], dest[S], top[S], bot[S], next[S], etot;
int sin[N], sout[N];
Dinic D;
void init( int n ) {
this->n = n;
etot = ;
memset( head, , sizeof(head) );
memset( sin, , sizeof(sin) );
memset( sout, , sizeof(sout) );
}
void adde( int u, int v, int t, int b ) {
// fprintf( stderr, "TopBot::adde( %d %d [%d,%d] )\n", u, v, b, t );
etot++;
dest[etot] = v;
top[etot] = t;
bot[etot] = b;
next[etot] = head[u];
head[u] = etot;
sin[v] += b;
sout[u] += b;
}
bool ok() {
int src=n+, dst=n+;
D.init( n+, src, dst );
for( int u=; u<=n; u++ )
for( int t=head[u]; t; t=next[t] ) {
int v=dest[t];
D.adde( u, v, top[t]-bot[t] );
}
int sumf = ;
for( int u=; u<=n; u++ ) {
if( sin[u]>sout[u] )
D.adde( src, u, sin[u]-sout[u] );
else if( sin[u]<sout[u] ) {
D.adde( u, dst, sout[u]-sin[u] );
sumf += sout[u]-sin[u];
}
}
// fprintf( stderr, "sumf=%d\n", sumf );
return D.maxflow()==sumf;
}
}T; int n, m;
int w[N][N], L, R;
int s[][N]; bool ok( int mid ) {
int src = n+m+, dst = n+m+;
int st=, sb=;
T.init(dst);
for( int i=; i<=n; i++ ) {
int t=s[][i]+mid, b=s[][i]-mid;
b = b< ? : b;
T.adde( src, i, t, b );
st += t;
sb += b;
}
for( int i=; i<=n; i++ )
for( int j=; j<=m; j++ )
T.adde( i, n+j, R, L );
for( int i=; i<=m; i++ ) {
int t=s[][i]+mid, b=s[][i]-mid;
b = b< ? : b;
T.adde( n+i, dst, t, b );
}
T.adde( dst, src, st, sb );
return T.ok();
}
int main() {
scanf( "%d%d", &n, &m );
for( int i=; i<=n; i++ )
for( int j=; j<=m; j++ ) {
scanf( "%d", &w[i][j] );
s[][i] += w[i][j];
s[][j] += w[i][j];
}
scanf( "%d%d", &L, &R );
int lf=, rg=;
while( lf<rg ) {
int mid=lf+((rg-lf)>>);
if( ok(mid) ) rg=mid;
else lf=mid+;
}
printf( "%d\n", lf );
}
bzoj 2406 二分+有源有汇上下界网络流可行流判定的更多相关文章
- sgu 194 上下界网络流可行流判定+输出可行流
#include <cstdio> #include <cstring> #define min(a,b) ((a)<(b)?(a):(b)) #define oo 0x ...
- POJ 2396 Budget(有源汇上下界网络流)
Description We are supposed to make a budget proposal for this multi-site competition. The budget pr ...
- ACM-ICPC 2018 沈阳赛区网络预赛 F. Fantastic Graph (贪心或有源汇上下界网络流)
"Oh, There is a bipartite graph.""Make it Fantastic."X wants to check whether a ...
- HDU 4940 Destroy Transportation system(无源汇上下界网络流)
Problem Description Tom is a commander, his task is destroying his enemy’s transportation system. Le ...
- [ACdream 1211 Reactor Cooling]无源无汇有上下界的可行流
题意:无源无汇有上下界的可行流 模型 思路:首先将所有边的容量设为上界减去下界,然后对一个点i,设i的所有入边的下界和为to[i],所有出边的下界和为from[i],令它们的差为dif[i]=to[i ...
- LOJ #116 有源汇点有上下界的最大流
先连一条从汇点到源点的容量为INF的边,将其转化成无源汇点有上下界的可行流,判断是否可行 若可行的话删掉超级源点和超级汇点,再跑一遍最大流即可 #include <iostream> #i ...
- ZOJ 2314 带上下界的可行流
对于无源汇问题,方法有两种. 1 从边的角度来处理. 新建超级源汇, 对于每一条有下界的边,x->y, 建立有向边 超级源->y ,容量为x->y下界,建立有向边 x-> 超级 ...
- HDU Destroy Transportation system(有上下界的可行流)
前几天正看着网络流,也正研究着一个有上下界的网络流的问题,查看了很多博客,觉得下面这篇概括的还是相当精确的: http://blog.csdn.net/leolin_/article/details/ ...
- ACM-ICPC 2018 沈阳赛区网络预赛 F Fantastic Graph(贪心或有源汇上下界网络流)
https://nanti.jisuanke.com/t/31447 题意 一个二分图,左边N个点,右边M个点,中间K条边,问你是否可以删掉边使得所有点的度数在[L,R]之间 分析 最大流不太会.. ...
随机推荐
- rollup&&cube
group by 擴展 rollup&&cube --按job分組計算不同job的匯總工資 SELECT job, SUM (sal) FROM emp GROUP BY ...
- SDL封装的系统操作(转载)
Andrew Haung bluedrum@163.com SDL封装很多操作系统的功能,为了保证SDL程序可移植性,最好尽量用这一些封装函数,哪果没有的话,才使用各种操作本地函数. 对于如何封各个 ...
- 目标板通过nfs挂载根文件系统
目标板挂载根文件系统的方法有两种(这里所说的服务端就是ubuntu,Ubuntu已经成功安装了nfs服务,并且保证服务端与目标板ping 通) 第一种:等待开发板启动之后去挂载,此时文件系统从Flas ...
- .Net程序集强签名详解
强签名: 1. 可以将强签名的dll注册到GAC,不同的应用程序可以共享同一dll. 2. 强签名的库,或者应用程序只能引用强签名的dll,不能引用未强签名的dll,但是未强签名的dll可以引用强签名 ...
- dedecms调用文章列表第一篇和下面几篇不同的方法
{dede:arclist row=1 orderby=pubdate infolen=60 limit=0,1} <li class="dot1"><img s ...
- vue-cli脚手架安装
-1.安装淘宝镜像 $ alias cnpm="npm --registry=https://registry.npm.taobao.org \ --cache=$HOME/.npm/.ca ...
- Codeforces 988F Rain and Umbrellas(DP)
题目链接:http://codeforces.com/contest/988/problem/F 题目大意: 有三个整数a,n,m,a是终点坐标,给出n个范围(l,r)表示这块区域下雨,m把伞(p,w ...
- eclipse中Maven项目jar问题
eclipse中Maven项目jar包下载下来了,不然我们import是时候根本导入不进来,网上的方法都试过了,Maven仓库也清空过后重新下载过了,都解决不了. 后来发现虽然jar包是下载下来了,可 ...
- Filebeat入门
一.安装filebeat 简介 Beats 是安装在服务器上的数据中转代理. Beats 可以将数据直接传输到 Elasticsearch 或传输到 Logstash . Beats 有多种类型,可以 ...
- webpack性能优化-实战
题外话:年初项目重构上线,项目技术栈使用vue+webpack,测试执行整个打包流程需要10分钟,同时又因涉及三个渠道,部署好环境就需半个小时,这严重延误了上线进度,因此提高webpack构建效率,成 ...