[BZOJ2095][Poi2010]Bridges 最大流(混合图欧拉回路)
2095: [Poi2010]Bridges
Time Limit: 10 Sec Memory Limit: 259 MB
Description
YYD为了减肥,他来到了瘦海,这是一个巨大的海,海中有n个小岛,小岛之间有m座桥连接,两个小岛之间不会有两座桥,并且从一个小岛可以到另外任意一个小岛。现在YYD想骑单车从小岛1出发,骑过每一座桥,到达每一个小岛,然后回到小岛1。霸中同学为了让YYD减肥成功,召唤了大风,由于是海上,风变得十分大,经过每一座桥都有不可避免的风阻碍YYD,YYD十分ddt,于是用泡芙贿赂了你,希望你能帮他找出一条承受的最大风力最小的路线。
Input
输入:第一行为两个用空格隔开的整数n(2<=n<=1000),m(1<=m<=2000),接下来读入m行由空格隔开的4个整数a,b(1<=a,b<=n,a<>b),c,d(1<=c,d<=1000),表示第i+1行第i座桥连接小岛a和b,从a到b承受的风力为c,从b到a承受的风力为d。
Output
输出:如果无法完成减肥计划,则输出NIE,否则第一行输出承受风力的最大值(要使它最小)
Sample Input
1 2 2 4
2 3 3 4
3 4 4 4
4 1 5 4

Sample Output
HINT
从源点向入度大于出度的点连流量为入度减出度/2的边,从入度小于出度向汇点的点连流量为出度减入度/2的边;
如果这样的边能够跑满,那么这个点就得到了完全的调整。
对一条无向边,连这条边的方向反向,流量为1的边,表示将这条边反向,两个点的入度与出度得到调整;
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int N=,M=,inf=0x7fffffff;
struct edge{int zhong,next,flow;};
int a[M],b[M],c[M],d[M],delta[N],n,sum,m;
struct NetWork_Flow
{
edge s[M<<];
int S,T,e,adj[N],cur[N];
int dist[N],hd,tl,q[N],cnt[N];
inline void add(int qi,int zhong,int flow)
{s[++e].zhong=zhong,s[e].next=adj[qi],adj[qi]=e,s[e].flow=flow;}
inline void bfs()
{
memset(cnt,,sizeof(cnt)),memset(dist,,sizeof(dist));
hd=,tl=,dist[T]=,q[++tl]=T;
register int i,x;
while(hd<=tl)
for(x=q[hd++],++cnt[dist[x]],i=adj[x];i;i=s[i].next)
if(s[i^].flow&&!dist[s[i].zhong])
dist[s[i].zhong]=dist[x]+,q[++tl]=s[i].zhong;
}
inline int Shoot(int rt,int maxf)
{
if(rt==T||!maxf)return maxf;
register int i,x,u,f,ret=;
for(i=cur[rt];i;i=s[i].next)
if(dist[s[i].zhong]+==dist[rt])
{
f=Shoot(s[i].zhong,min(maxf,s[i].flow));
ret+=f,maxf-=f,s[i].flow-=f,s[i^].flow+=f;
if(!maxf)return ret;
}
if(!(--cnt[dist[rt]]))dist[S]=T+;
++cnt[++dist[rt]],cur[rt]=adj[rt];
return ret;
}
inline int ISAP()
{
register int i;
memcpy(cur,adj,sizeof(adj));
int maxf=;bfs();
while(dist[S]<=T+)maxf+=Shoot(S,inf);
return maxf;
}
inline void build(int val)
{
register int i;
e=,sum=,memset(adj,,sizeof(adj));
memset(delta,,sizeof(delta));
for(i=;i<=m;++i)
{
if(c[i]<=val)--delta[a[i]],++delta[b[i]];
if(d[i]<=val)
add(b[i],a[i],),add(a[i],b[i],);
}
for(i=;i<=n;++i)
if(delta[i]>)sum+=delta[i]/,add(S,i,delta[i]/),add(i,S,);
else add(i,T,-delta[i]/),add(T,i,);
}
inline bool check(int val)
{
register int i;
build(val);
for(i=;i<=n;++i)
if(delta[i]&)return ;
return ISAP()==sum;
}
}G;
int main()
{
scanf("%d%d",&n,&m);
G.S=n+,G.T=n+;
register int i,j;
int l=,r=,mi,ans=inf;
for(i=;i<=m;++i)
{
scanf("%d%d%d%d",&a[i],&b[i],&c[i],&d[i]);
if(c[i]>d[i])swap(c[i],d[i]),swap(a[i],b[i]);
l=min(l,c[i]),r=max(r,d[i]);
}
while(l<=r)
{
mi=l+r>>;
if(G.check(mi))r=mi-,ans=mi;
else l=mi+;
}
if(ans==inf)puts("NIE");
else printf("%d\n",ans);
}
[BZOJ2095][Poi2010]Bridges 最大流(混合图欧拉回路)的更多相关文章
- BZOJ2095 POI2010 Bridges 【二分+混合图欧拉回路】
BZOJ2095 POI2010 Bridges Description YYD为了减肥,他来到了瘦海,这是一个巨大的海,海中有n个小岛,小岛之间有m座桥连接,两个小岛之间不会有两座桥,并且从一个小岛 ...
- 【BZOJ-2095】Bridge 最大流 + 混合图欧拉回路 + 二分
2095: [Poi2010]Bridges Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 604 Solved: 218[Submit][Stat ...
- bzoj2095: [Poi2010]Bridges(二分+混合图求欧拉回路)
传送门 这篇题解讲的真吼->这里 首先我们可以二分一个答案,然后把所有权值小于这个答案的都加入图中 那么问题就转化为一张混合图(既有有向边又有无向边)中是否存在欧拉回路 首先 无向图存在欧拉回路 ...
- bzoj 2095: [Poi2010]Bridges(二分法+混合图的欧拉回路)
[题意] 给定n点m边的无向图,对于边u,v,从u到v边权为c,从v到u的边权为d,问能够经过每条边一次且仅一次,且最大权值最小的欧拉回路. [思路] 二分答案mid,然后切断权值大于mid的边,原图 ...
- BZOJ2095:[POI2010]Bridges(最大流,欧拉图)
Description YYD为了减肥,他来到了瘦海,这是一个巨大的海,海中有n个小岛,小岛之间有m座桥连接,两个小岛之间不会有两座桥,并且从一个小岛可以到另外任意一个小岛.现在YYD想骑单车从小岛1 ...
- BZOJ.2095.[POI2010]Bridges(最大流ISAP 二分 欧拉回路)
题目链接 最小化最大的一条边,二分答案.然后就变成了给一张无向图定向使其为欧拉回路 二分答案后对于一个位置的两条边可能都保留,即双向边,需要给它定向:可能只保留小的一条,即单向边,不需考虑 如何给它定 ...
- POJ 1637 - Sightseeing tour - [最大流解决混合图欧拉回路]
嗯,这是我上一篇文章说的那本宝典的第二题,我只想说,真TM是本宝典……做的我又痛苦又激动……(我感觉ACM的日常尽在这张表情中了) 题目链接:http://poj.org/problem?id=163 ...
- POJ 1637 Sightseeing tour(混合图欧拉回路+最大流)
http://poj.org/problem?id=1637 题意:给出n个点和m条边,这些边有些是单向边,有些是双向边,判断是否能构成欧拉回路. 思路: 构成有向图欧拉回路的要求是入度=出度,无向图 ...
- BZOJ2095 [Poi2010]Bridges
首先二分答案...然后这张图变成了有一些有向边,有一些无向边 然后就是混合图欧拉回路的判断 我们知道如果是有向图,它存在欧拉回路的等价条件是所有点的出度等于入度 对于混合图...先不管有向边,把无向边 ...
随机推荐
- 我所理解的selenium之PO设计模式
下午,花了点时间来整理UI自动化设计,就把我所理解的PO设计模式项目结构脑图整理如下,有不对的地方还望多多包涵.谢谢
- 精确的double加减乘除运算工具类
import java.math.BigDecimal; /** * 精确的double加减乘除运算 * @author cyf * */ public class DoubleUtil { /** ...
- elementUI实现前端分页
按照他的文档来写分页,最主要的是el-table里面展示的数据怎么处理 <el-table :data="AllCommodityList.slice((currentPage-1)* ...
- NIKTO介绍及使用方法
1. NIKTO:perl语言开发的开源WEB安全扫描器:识别网站软件版本:搜索存在安全隐患的文件:检查服务器配置漏洞:检查WEB Application层面的安全隐患:避免404误判(原因:很 ...
- IEEE1588 ( PTP ) 协议简介
IEEE1588 协议,又称 PTP( precise time protocol,精确时间协议),可以达到亚微秒级别时间同步精度,于 2002 年发布 version 1,2008 年发布 vers ...
- ats Linux Bridge内联
Linux可以配置为在桥接模式下运行. 为网桥分配了两个或更多物理接口. 在接口之间共享单个IP地址. 默认情况下,任何到达一个接口的数据包都会立即路由到另一个网桥接口. 需要的Linux包: bri ...
- 《how tomcat works》阅读笔记 - 2 - 门面设计模式,避免强制转换
在第二章 2.3节中 try { servlet = (Servlet) myClass.newInstance(); servlet.service((ServletRequest) request ...
- node上的__dirname和./的区别
概要 Node.js 中,__dirname 总是指向被执行 js 文件的绝对路径,所以当你在 /d1/d2/myscript.js 文件中写了 __dirname, 它的值就是 /d1/d2 . 相 ...
- 2018-2019-20172329 《Java软件结构与数据结构》第八周学习总结
2018-2019-20172329 <Java软件结构与数据结构>第八周学习总结 现在对于我而言,最珍贵的是时间,感觉自己在时间飞逝的时候真的挽留不住什么,只能怒发冲冠的让自己疯狂的学习 ...
- 求int型数组和最大子数组 续
之前的博文里已经实现过该程序的构思.编译.运行,本次就不再重复与之相雷同的内容. 题目:与别人借组,借助求int型数组最大和子数组的问题,考虑大数溢出和int取值范围的问题 要求: 调试程序 当子数 ...