poj 1637 混合图欧拉回路 学习笔记
题目大意
求混合图是否存在欧拉回路
做法
有向边我们只有增加入度出度
对于无向边,我们给它设定一个初始方向
如果不能满足|入度-出度|为偶数,无解
然后在网络流图中,
设设定方向的反向连一条边,表示反悔流量
对于最后in>out的点,最多可以提供反悔(in-out)/2点反悔流量,从源点连向它
对于out>in的点,至少接受(out-in)/2点反悔流量,连向汇点
跑一次网络流判断是否满流
由于图中一条边提供一个入度,一个出度
所以图中总入度是等于总出度的
网络流中两边流量是一样的
注意
sb我还要错多少次
网络流连边的数组还要考虑到连源点汇点的边
数组开大一点会死咩
分析
#include <cstdio>
#include <cstdio>
#include <cstring>
#include <cctype>
#include <cmath>
#include <algorithm>
using namespace std;
const int M=207;
const int S=0;
const int T=201;
const int INF=1e9;
inline int rd(){
int x=0;bool f=1;char c=getchar();
for(;!isdigit(c);c=getchar()) if(c=='-') f=0;
for(;isdigit(c);c=getchar()) x=x*10+c-48;
return f?x:-x;
}
int tcas;
int n,m;
int in[M];
int ot[M];
int g[M],te;
struct edge{int y,f,next;}e[2407];
void addedge(int x,int y,int f){
e[++te].y=y;e[te].f=f;e[te].next=g[x];g[x]=te;
e[++te].y=x;e[te].f=0;e[te].next=g[y];g[y]=te;
}
int q[M],tq;
int lev[M];
bool bfs(){
int h=0,t=1,x,p,y;
memset(lev,-1,sizeof(lev));
q[1]=S; lev[S]=0;
while(h^t){
int x=q[++h];
for(p=g[x];p;p=e[p].next)
if(e[p].f&&lev[y=e[p].y]==-1){
lev[y]=lev[x]+1;
if(y==T) return 1;
q[++t]=y;
}
}
return 0;
}
int dfs(int x,int fl){
if(x==T) return fl;
int p,y;
int tp,res=0;
for(p=g[x];p;p=e[p].next)
if(e[p].f&&lev[x]+1==lev[y=e[p].y]){
tp=dfs(y,min(fl,e[p].f));
if(tp){
e[p].f-=tp;
e[p^1].f+=tp;
res+=tp;
fl-=tp;
if(fl==0) return res;
}
}
if(res==0) lev[x]=-1;
return res;
}
int main(){
int i,x,y,z,res;
tcas=rd();
while(tcas--){
n=rd();
m=rd();
memset(in,0,sizeof(in));
memset(ot,0,sizeof(ot));
memset(g,0,sizeof(g)); te=1;
for(i=1;i<=m;i++){
x=rd(),y=rd(),z=rd();
ot[x]++;
in[y]++;
if(z==0) addedge(y,x,1);
}
z=0;
for(i=1;i<=n;i++)
if((in[i]-ot[i])%2==1) {z=1;break;}
if(z) puts("impossible");
else{
res=0;
for(i=1;i<=n;i++){
z=abs(in[i]-ot[i])/2;
if(!z) continue;
if(in[i]>ot[i]) addedge(S,i,z);
else addedge(i,T,z),res+=z;
}
while(bfs()) res-=dfs(S,INF);
if(res>0) puts("impossible");
else puts("possible");
}
}
return 0;
}
poj 1637 混合图欧拉回路 学习笔记的更多相关文章
- POJ 1637 混合图欧拉回路
先来复习一下混合图欧拉回路:给定一张含有单向边和双向边的图,使得每一点的入度出度相同. 首先对于有向边来说,它能贡献的入度出度是确定的,我们不予考虑.对于无向图,它可以通过改变方向来改变两端点的出入度 ...
- POJ 1637 混合图的欧拉回路判定
题意:一张混合图,判断是否存在欧拉回路. 分析参考: 混合图(既有有向边又有无向边的图)中欧拉环.欧拉路径的判定需要借助网络流! (1)欧拉环的判定:一开始当然是判断原图的基图是否连通,若不连通则一定 ...
- POJ 1637 混合图求欧拉回路 最大流实现
前面讲过了无向图,有向图求欧拉回路,欧拉通路的做法.可以直接根据度数来判断,当然前提是这是一个连通图. 这道题既有无向边,又有有向边,然后求欧拉回路. 采用的方法是最大流. 具体处理方法. 首先,我们 ...
- POJ 1637 - Sightseeing tour - [最大流解决混合图欧拉回路]
嗯,这是我上一篇文章说的那本宝典的第二题,我只想说,真TM是本宝典……做的我又痛苦又激动……(我感觉ACM的日常尽在这张表情中了) 题目链接:http://poj.org/problem?id=163 ...
- POJ 1637 Sightseeing tour(混合图欧拉回路+最大流)
http://poj.org/problem?id=1637 题意:给出n个点和m条边,这些边有些是单向边,有些是双向边,判断是否能构成欧拉回路. 思路: 构成有向图欧拉回路的要求是入度=出度,无向图 ...
- POJ 1637 Sightseeing tour ★混合图欧拉回路
[题目大意]混合图欧拉回路(1 <= N <= 200, 1 <= M <= 1000) [建模方法] 把该图的无向边随便定向,计算每个点的入度和出度.如果有某个点出入度之差为 ...
- Sightseeing tour 【混合图欧拉回路】
题目链接:http://poj.org/problem?id=1637 Sightseeing tour Time Limit: 1000MS Memory Limit: 10000K Total ...
- 【BZOJ-2095】Bridge 最大流 + 混合图欧拉回路 + 二分
2095: [Poi2010]Bridges Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 604 Solved: 218[Submit][Stat ...
- poj1637Sightseeing tour(混合图欧拉回路)
题目请戳这里 题目大意:求混合图欧拉回路. 题目分析:最大流.竟然用网络流求混合图的欧拉回路,涨姿势了啊啊.. 其实仔细一想也是那么回事.欧拉回路是遍历所有边一次又回到起点的回路.双向图只要每个点度数 ...
随机推荐
- 使用notepad++远程编辑Linux文档
上一篇中,我写了如何使用使用ftp服务器实现很方便的通信,这一篇我分享一个使用notepad++的一个NPPFTP插件远程编辑Linux中的文档的小技巧. 首先要确保你的Linux的ftp服务已经打开 ...
- 使用lua做序列化和反序列化
-- lua对象序列化 function serialize(obj) local lua = "" local t = type(obj) if t == "numbe ...
- 探讨 JS 的面向对象中继承的那些事
最近学了 JS 的面向对象,这篇文章主要是探讨 JS 的面向对象中继承的那些事. JS中继承的特点: 1.子类继承父类: 2.子类可以用父类的方法和属性 3.子类的改变可以不影响父类 下面用一个例子来 ...
- 解决 viewer.js 动态更新图片导致无法预览的问题
1.viewer.js 使用 Demo http://fengyuanchen.github.io/viewerjs/ 2.viewer.js 下载地址 https://github.com/feng ...
- python之函数基础总结
定义:函数是指将一组语句的集合通过一个名字(函数名)封装起来,要想执行这个函数,只需调用其函数名即可. def sayhi(name): print("Hello, %s, I', nobo ...
- HDU - 1465 不容易系列之一(错排)
HDU有个网名叫做8006的男性同学,结交网友无数,最近该同学玩起了浪漫,同时给n个网友每人写了一封信,这都没什么,要命的是,他竟然把所有的信都装错了信封!注意了,是全部装错哟! 现在的问题是:请大家 ...
- Linux学习-额外(单一)核心模块编译
编译前注意事项 由于我们的核心原本就有提供很多的核心工具给硬件开发商来使用, 而硬件开发商也需要针对核心 所提供的功能来设计他们的驱动程序模块,因此, 我们如果想要自行使用硬件开发商所提供的模块 来进 ...
- UVa 10564 DP Paths through the Hourglass
从下往上DP,d(i, j, k)表示第(i, j)个格子走到底和为k的路径条数. 至于字典序最小,DP的时候记录一下路径就好. #include <cstdio> #include &l ...
- 从Windows想Linux上传文件 Linux(CentOS) 上安装vsftpd
今天想在Linux上搭建个LAMP环境,以前用的Linux都安装了图形界面,但是这次用的阿里云服务器是纯命令模式,用起来有点不大适应. 最大的不适应就是获取apache等软件了,以前直接登录相应网站, ...
- Linux中 find 常见用法示例
Linux中find常见用法示例 #find path -option [ -print ] [ -exec -ok command ] {} \; #-print 将查找到的文件输出到标准输出 #- ...