弱爆了,典型的行列建模方式,居然想不到,题做少了,总结少了。。。。。。

二分答案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 二分+有源有汇上下界网络流可行流判定的更多相关文章

  1. sgu 194 上下界网络流可行流判定+输出可行流

    #include <cstdio> #include <cstring> #define min(a,b) ((a)<(b)?(a):(b)) #define oo 0x ...

  2. POJ 2396 Budget(有源汇上下界网络流)

    Description We are supposed to make a budget proposal for this multi-site competition. The budget pr ...

  3. ACM-ICPC 2018 沈阳赛区网络预赛 F. Fantastic Graph (贪心或有源汇上下界网络流)

    "Oh, There is a bipartite graph.""Make it Fantastic."X wants to check whether a ...

  4. HDU 4940 Destroy Transportation system(无源汇上下界网络流)

    Problem Description Tom is a commander, his task is destroying his enemy’s transportation system. Le ...

  5. [ACdream 1211 Reactor Cooling]无源无汇有上下界的可行流

    题意:无源无汇有上下界的可行流 模型 思路:首先将所有边的容量设为上界减去下界,然后对一个点i,设i的所有入边的下界和为to[i],所有出边的下界和为from[i],令它们的差为dif[i]=to[i ...

  6. LOJ #116 有源汇点有上下界的最大流

    先连一条从汇点到源点的容量为INF的边,将其转化成无源汇点有上下界的可行流,判断是否可行 若可行的话删掉超级源点和超级汇点,再跑一遍最大流即可 #include <iostream> #i ...

  7. ZOJ 2314 带上下界的可行流

    对于无源汇问题,方法有两种. 1 从边的角度来处理. 新建超级源汇, 对于每一条有下界的边,x->y, 建立有向边 超级源->y ,容量为x->y下界,建立有向边 x-> 超级 ...

  8. HDU Destroy Transportation system(有上下界的可行流)

    前几天正看着网络流,也正研究着一个有上下界的网络流的问题,查看了很多博客,觉得下面这篇概括的还是相当精确的: http://blog.csdn.net/leolin_/article/details/ ...

  9. ACM-ICPC 2018 沈阳赛区网络预赛 F Fantastic Graph(贪心或有源汇上下界网络流)

    https://nanti.jisuanke.com/t/31447 题意 一个二分图,左边N个点,右边M个点,中间K条边,问你是否可以删掉边使得所有点的度数在[L,R]之间 分析 最大流不太会.. ...

随机推荐

  1. torch.nn.CrossEntropyLoss

    class torch.nn.CrossEntropyLoss(weight=None, size_average=True, ignore_index=-100, reduce=True) 我这里没 ...

  2. jQuery对象与JS原生对象之间的转换

    1.将jQuery转换为dom对象的方法 [index] 或者.get(index): a.$(“#form”)[index] ,该方法获取form元素的dom对象 b.$(“#form”).get( ...

  3. epoll对poll(select)的改进

    select的几大缺点:   每次调用select,都需要把fd集合从用户态拷贝到内核态,这个开销在fd很多时会很大: 每次调用select,内核需要遍历传递进来的所有fd(判断检测文件是否可用).有 ...

  4. Ajax请求中的async:false/true

    Ajax请求中的async:false/trueasync. 默认是 true,即为异步方式,$.ajax执行后,会继续执行ajax后面的脚本,直到服务器端返回数据后,触发$.ajax里的succes ...

  5. HTML5练习2

    1.邮箱注册网页 主要代码: <!doctype html> <html> <meta charset="utf-8"> <title&g ...

  6. Android 客户端 okhttp3 与服务器之间的双向验证

    [原文]https://blog.csdn.net/leng_wen_rou/article/details/58596142 本篇是Android 客户端基于okhttp3的网络框架 和后台服务器之 ...

  7. 何时调用getView?——从源码的角度给出解答

    先来看ListView类中的makeAndAddView方法: 没有数据变化:从mRecycler中取得可视的view 数据有变化:obtainView /** * 获取视图填充到列表的item中去, ...

  8. spring boot之使用通用Mapper批量添加数据

    通用Mapper是一款针对mybatis进行扩展的轻量级组件,使用起来非常方便.当调用其针对mysql进行批量添加数据的方法时,发现报错,仔细研究了一番,发现是在使用通用Mapper上出现了问题.下面 ...

  9. 自定义排序及Hadoop序列化

    自定义排序 将两列数据进行排序,第一列按照升序排列,当第一列相同时,第二列升序排列. 在map和reduce阶段进行排序时,比较的是k2.v2是不参与排序比较的.如果要想让v2也进行排序,需要把k2和 ...

  10. hdoj1102 Constructing Roads(Prime || Kruskal)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=1102 题意 有n个村庄(编号1~n),给出n个村庄之间的距离,开始时n个村庄之间已经有了q条路,现在需 ...