题意

一个 \(n\) 个点 \(m\) 条边的图,每条边双向都有权值(可能不一样)。求从 1 开始,经过所有点,经过所有边一次且仅一次(即一定要经过这条边的某个方向)回到 1 的路径上权值最大的最小是多少。\(n\le 1000,m\le 2000\) 。

分析

显然二分答案,判定是否存在欧拉回路。

欧拉回路的判定用网络流方法。

若是一个有向图,存在欧拉欧拉回路的充要条件是每个点入度等于出度。但这是一个混合图,含有无向边,所以我们要看看无向边走哪个方向,使得每个点的入度等于出度。

对于一条无向边,任意定向,先判断每个点的入度出度之差是否是偶数。若不是,那么无论如何更改方向都不能满足条件。若是偶数,这实际上就告诉我们,每个点有多少入度或者出度需要更改。

设 \(d_x\) 为 \(x\) 点的入度减出度,那么若 \(d_x>0\) ,向汇点连 \(\frac{d_x}{2}\) 的边,否则从源点连 \(\frac{|d_x|}{2}\) 的边。对于任意定向的无向边,给 1 的容量。

考虑这个网络上的一条增广路,它的含义是把这个路径上的边全部反向。注意,这只影响了开头的点和末尾的点的入度与出度关系。具体来说,起始点的入度加一,出度减一;末尾点的入度减一,出度加一。若源点出边满流,就说明,每个点的不合法出度已经被全部更改完了,那么每个点的不合法出度也相应地更改完了。也就是说,原来任意定向的边有 1 的流量,那么把这条边反过来,这样构造的新图是满足每个点的入度等于出度的,即存在欧拉回路。

复杂度为 \(O(n^2m\log w)\) 。

UPD: 这题的可二分性有待讨论,搞不好这题是错的。

代码

#include<bits/stdc++.h>
#define M(x) memset(x,0,sizeof x)
using namespace std;
inline char nchar() {
static const int bufl=1<<20;
static char buf[bufl],*a,*b;
return a==b && (b=(a=buf)+fread(buf,1,bufl,stdin),a==b)?EOF:*a++;
}
inline int read() {
int x=0,f=1;
char c=nchar();
for (;!isdigit(c);c=nchar()) if (c=='-') f=-1;
for (;isdigit(c);c=nchar()) x=x*10+c-'0';
return x*f;
}
const int maxn=1e3+10;
const int maxm=4e3+10;
template<typename T> inline void Max(T &x,T y) {x=max(x,y);}
int n,m,f[maxn],all,ind[maxn],oud[maxn];
int find(int x) {return f[x]==x?x:f[x]=find(f[x]);}
struct bian {
int x,y,a,b;
} b[maxm];
struct some {
int x,y;
bool bi; // true: undir; false: dir
} a[maxm];
namespace graph {
struct edge {
int v,w,nxt;
} e[maxm];
int h[maxn],tot,que[maxn],ql,qr,d[maxn];
inline void clear() {
memset(h,-1,sizeof h);
tot=1;
}
inline void add(int x,int y,int w) {
e[++tot]=(edge){y,w,h[x]};
h[x]=tot;
e[++tot]=(edge){x,0,h[y]};
h[y]=tot;
}
inline bool bfs(int s,int t) {
memset(d,0,sizeof d);
d[que[ql=qr=1]=s]=1;
while (ql<=qr) {
int x=que[ql++];
for (int i=h[x],v=e[i].v;i;i=e[i].nxt,v=e[i].v) if (e[i].w && !d[v]) d[que[++qr]=v]=d[x]+1;
}
return d[t];
}
int dfs(int x,int t,int mi) {
if (x==t) return mi;
int flow=0;
for (int i=h[x],v=e[i].v;i;i=e[i].nxt,v=e[i].v) if (e[i].w && d[v]==d[x]+1) {
int tmp=dfs(v,t,min(mi,e[i].w));
if (!tmp) {d[v]=0;continue;}
e[i].w-=tmp,e[i^1].w+=tmp,mi-=tmp,flow+=tmp;
if (!mi) break;
}
return flow;
}
inline int maxflow(int s,int t) {
int ret=0;
while (bfs(s,t)) ret+=dfs(s,t,INT_MAX);
return ret;
}
}
inline bool check() {
M(ind),M(oud);
for (int i=1;i<=all;++i) ++ind[a[i].y],++oud[a[i].x];
for (int i=1;i<=n;++i) if ((ind[i]-=oud[i])&1) return false; else ind[i]>>=1;
int S=0,T=n+1,sm=0;
graph::clear();
for (int i=1;i<=all;++i) if (a[i].bi) graph::add(a[i].x,a[i].y,1);
for (int i=1;i<=n;++i) if (ind[i]>0) graph::add(i,T,ind[i]); else if (ind[i]<0) graph::add(S,i,-ind[i]),sm-=ind[i];
int flow=graph::maxflow(S,T);
return flow==sm;
}
inline bool ok(int mx) {
for (int i=1;i<=n;++i) f[i]=i;
int cnt=n;
for (int i=1;i<=m;++i) if (b[i].a<=mx || b[i].b<=mx) {
int fx=find(b[i].x),fy=find(b[i].y);
if (fx!=fy) f[fx]=fy,--cnt;
}
if (cnt>1) return false;
all=0;
for (int i=1;i<=m;++i) if (b[i].a<=mx && b[i].b<=mx) a[++all]=(some){b[i].x,b[i].y,true}; else {
if (b[i].a<=mx) a[++all]=(some){b[i].x,b[i].y,false};
if (b[i].b<=mx) a[++all]=(some){b[i].y,b[i].x,false};
}
return check();
}
int main() {
#ifndef ONLINE_JUDGE
freopen("test.in","r",stdin);
#endif
int l=1,r=0,ans;
n=read(),m=read();
for (int i=1;i<=m;++i) b[i].x=read(),b[i].y=read(),b[i].a=read(),b[i].b=read(),Max(r,max(b[i].a,b[i].b));
while (l<=r) {
int mid=l+r>>1;
if (ok(mid)) ans=mid,r=mid-1; else l=mid+1;
}
ans?printf("%d\n",ans):puts("NIE");
return 0;
}

bzoj2095-Bridge的更多相关文章

  1. 【BZOJ-2095】Bridge 最大流 + 混合图欧拉回路 + 二分

    2095: [Poi2010]Bridges Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 604  Solved: 218[Submit][Stat ...

  2. 【BZOJ2095】【POI2010】Bridge 网络流

    题目大意 ​ 给你一个无向图,每条边的两个方向的边权可能不同.要求找出一条欧拉回路使得路径上的边权的最大值最小.无解输出"NIE". \(2\leq n\leq 1000,1\le ...

  3. 【BZOJ2095】 Bridge

    Time Limit: 1000 ms   Memory Limit: 128 MB Description YYD为了减肥,他来到了瘦海,这是一个巨大的海,海中有n个小岛,小岛之间有m座桥连接,两个 ...

  4. PHP设计模式(八)桥接模式(Bridge For PHP)

    一.概述 桥接模式:将两个原本不相关的类结合在一起,然后利用两个类中的方法和属性,输出一份新的结果. 二.案例 1.模拟毛笔(转) 需求:现在需要准备三种粗细(大中小),并且有五种颜色的比 如果使用蜡 ...

  5. Configure a bridge interface over a VLAN tagged bonded interface

    SOLUTION VERIFIED February 5 2014 KB340153 Environment Red Hat Enterprise Linux 6 (All Versions) Red ...

  6. Create a bridge using a tagged vlan (8021.q) interface

    SOLUTION VERIFIED April 27 2013 KB26727 Environment Red Hat Enterprise Linux 5 Red Hat Enterprise Li ...

  7. Configure bridge on a team interface using NetworkManager in RHEL 7

    SOLUTION IN PROGRESS February 29 2016 KB2181361 environment Red Hat Enterprise Linux 7 Teaming,Bridg ...

  8. 理解 neutron(15):Neutron linux-bridge-agent 创建 linux bridge 的简要过程

    学习 Neutron 系列文章: (1)Neutron 所实现的虚拟化网络 (2)Neutron OpenvSwitch + VLAN 虚拟网络 (3)Neutron OpenvSwitch + GR ...

  9. KVM 虚拟机联网方式:NAT 和 Bridge

    KVM 客户机网络连接有两种方式: 用户网络(User Networking):让虚拟机访问主机.互联网或本地网络上的资源的简单方法,但是不能从网络或其他的客户机访问客户机,性能上也需要大的调整.NA ...

  10. 桥接模式/bridge模式/对象结构型

    意图 将抽象部分与它的实现部分分离,使它们都可以独立的变化. 动机 当一个抽象类有多个实现时,通常用继承来协调它们.但是继承机制将抽象和实现固定,难以对抽象部分和实现部分独立地进行修改.扩充和重用. ...

随机推荐

  1. 大同世界的Java 和.NET 开发

    1.作为一个科班出生的根正苗红的软件开发人员,我认为现在的一群年轻的程序员总是在讨论JAVA  好还是.NET 好的同时,我作为一个做4年开发的.NET 程序员中间穿插了1年JAVA 开发的来说更加的 ...

  2. Tomcat学习(二)------Tomcat原理详解及请求过程

    Tomcat: Tomcat是一个JSP/Servlet容器.其作为Servlet容器,有三种工作模式:独立的Servlet容器.进程内的Servlet容器和进程外的Servlet容器. Tomcat ...

  3. 《javascript语言精粹》mindmap

    最近刚刚读完<javascript语言精粹>,感觉其中的内容确实给用js作开发语言的童鞋们提了个醒——js里面坑很多啊 不过,我也并不完全认同书中所讲的所有内容,有些书中认为是糟粕的特性, ...

  4. java随记

    jdk1.8中新增了 LocalDate 与 LocalDateTime等类来解决日期处理方法,同时引入了一个新的类DateTimeFormatter来解决日期格式化问题. LocalDateTime ...

  5. 优化JDBC开发

    一.元数据 元数据:数据库.表.列的定义信息 1.DataBaseMetaData对象 getURL():返回一个String类对象,代表数据库的URL. getUserName():返回连接当前数据 ...

  6. Jmeter参数的AES加密使用

    在Jmeter日常实践中,大家应该都遇到过接口传参需要加密的情况.以登陆为例,用户名和密码一般都需要进行加密传输,在服务端再进行解密,这样安全系数会更高,但在使用jmeter进行接口测试的时候,怎样发 ...

  7. Linux golang使用cgo调用C++标准库问题

    我们知道cgo无法直接调用c++方法,但是可以通过c包装c++方法,以达到使用的目的. C++中,我们经常会用到STL.在cgo中,如果要调用STL,需要作如下操作: //cgo LDFLAGS: - ...

  8. 测试目录结构Aegisub【自用笔记】

    手册链接https://aegi.vmoe.info/docs/3.2/Main_Page/ 01,加粗   b标签 1开启 其他或不写则关闭 买{\b1}苹果{\b0}123 02,倾斜   i标签 ...

  9. 2019第十届蓝桥杯 E题 迷宫

    /*输入 30 50 01010101001011001001010110010110100100001000101010 00001000100000101010010000100000001001 ...

  10. TensorFlow学习之路1-TensorFlow介绍

    TensorFlow是一个采用数据流图(data flow graphs),用于数据计算的开源软件库. 什么是数据流图? TensorFlow的数据流图是由“节点”(nodes)和“线”(edges) ...