写了一道欧拉回路的模板题。先判断是否是欧拉回路,有向图和无向图有一点点不同,然后就是特判独立点的存在。

之后是输出路径,和dls学的dfs,利用last数组的更新可以做到线性的复杂度,否则一不小心就会写成m^2的复杂度

附上代码——by VANE

 #include<bits/stdc++.h>
using namespace std;
int t,n,m;
const int N=;
int l,last[N],pre[N<<],other[N<<],f[N];
int rd[N],cd[N];
int getfa(int x)
{
return x==f[x]?x:f[x]=getfa(f[x]);
}
bool not_lone[N];
bool vis[N<<];
void add(int a,int b,int c)
{
if(c==)
{++l;pre[l]=last[a];last[a]=l;other[l]=b;}
else
{int L=l+m;pre[L]=last[a];last[a]=L;other[L]=b;}
}
void merge(int x,int y)
{
int fx=getfa(x),fy=getfa(y);
if(fx!=fy)
f[fx]=fy;
}
int abs(int x)
{
return x<=m?x:x-m;
}
int val(int x)
{
return x<=m?x:m-x;
}
stack<int> sk;
void dfs(int x)
{
for(int p=last[x];p;p=last[x])
{
while(vis[abs(p)]&&p) p=pre[p];
last[x]=p;
if(p)
{
vis[abs(p)]=;
dfs(other[p]);
sk.push(val(p));
}
} }
int main()
{
scanf("%d%d%d",&t,&n,&m);
for(int i=;i<=n;++i) f[i]=i;
for(int i=;i<=m;++i)
{
int x,y;scanf("%d%d",&x,&y);
add(x,y,);if(t==) add(y,x,m);
cd[x]++;rd[y]++;
not_lone[x]=not_lone[y]=;
merge(x,y);
}
int rt=;
for(int i=;i<=n;++i)
{
if(not_lone[i])
{
rt=i;break;
}
}
for(int i=;i<=n;++i)
if(not_lone[i]&&getfa(i)!=getfa(rt))
{
puts("NO");
return ;
}
if(t==)
{
for(int i=;i<=n;++i)
if((rd[i]+cd[i])&)
{puts("NO");return ;}
}
else
{
for(int i=;i<=n;++i)
if(rd[i]!=cd[i])
{puts("NO");return ;}
}
for(int i=;i<=n;++i)
if(not_lone[i])
{
dfs(i);
break;
}
puts("YES");
while(!sk.empty())
{
printf("%d ",sk.top());
sk.pop();
}
}

下面的By:大奕哥

我们就直接搜索啦,对于无向图需要保证的性质是任何点的出度+入度都要为偶数,对于有向图任意点的出度都要等于入度。

搜索就是一个回溯的过程,然后每次我们都把边删掉(head[x]=i)

然后如果要是能搜的话我们就加入队列。

在这里要特别注意对于孤立点(无任何边连入无任何边连出)的点,搜索从任意一个连边的点即可。

 #include<bits/stdc++.h>
using namespace std;
const int N=;
int n,m,top,cnt,f[N],head[N],d1[N],d2[N],q[N];
struct node
{
int to,nex,w;
}e[N<<];
void add(int x,int y,int w)
{
e[++cnt].to=y;e[cnt].nex=head[x];
head[x]=cnt;e[cnt].w=w;
d1[x]++;d2[y]++;
}
void dfs(int x)
{
for(int i=head[x];i;i=head[x])
{
while(i&&f[abs(e[i].w)])i=e[i].nex;
head[x]=i;
if(i)
{
f[abs(e[i].w)]=;
dfs(e[i].to);
q[++top]=e[i].w;
}
}
}
int main()
{
int n,m,x,y,p,k;
scanf("%d%d%d",&p,&n,&m);
for(int i=;i<=m;++i)
{
scanf("%d%d",&x,&y);
add(x,y,i);
if(p==)add(y,x,-i);
}
for(int i=;i<=n;++i)if(p==&&d1[i]%||p==&&d1[i]!=d2[i]){puts("NO");return ;}
dfs(x);
if(top<m){puts("NO");return ;}
puts("YES");
for(int i=top;i;--i)printf("%d ",q[i]);
return ;
}

欧拉回路 uoj117的更多相关文章

  1. 算法复习——欧拉回路(uoj117)

    题目: 题解: 欧拉回路相关定理(相关定义和证明请参见其他资料): 1.欧拉回路 (1)有向图:所有点的出度都等于入度为该图为欧拉图(存在欧拉回路)的充要条件. (2)无向图:所有点的度都为偶数为该图 ...

  2. 求欧拉回路 UOJ117

    传送门什么是欧拉回路呢……?欧拉回路的定义就是从vi出发到vi,经过每条边有且只有一次的路径. 就很像一笔画. 欧拉回路的性质较多……定理也很多……直接证明很长……我们还是直接说怎么判定,怎么求欧拉回 ...

  3. UOJ117. 欧拉回路【欧拉回路模板题】

    LINK 题目大意 就是让你对有向图和无向图分别求欧拉回路 非常的模板,但是由于UOJ上毒瘤群众太多了 所以你必须加上一个小优化 就是每次访问过一个边就把它删掉 有点像Dinic的当前弧优化的感觉 注 ...

  4. uoj117 欧拉回路

    题目描述: 有一天一位灵魂画师画了一张图,现在要你找出欧拉回路,即在图中找一个环使得每条边都在环上出现恰好一次. 一共两个子任务: 这张图是无向图.(50 分) 这张图是有向图.(50 分) 输入格式 ...

  5. UOJ117:欧拉回路——题解

    http://uoj.ac/problem/117 (作为一道欧拉回路的板子题,他成功的令我学会了欧拉回路) (然而我不会背……) 就两件事: 1.无向图为欧拉图,当且仅当为连通图且所有顶点的度为偶数 ...

  6. UOJ117 欧拉回路[欧拉回路]

    找欧拉回路的模板题. 知识点详见图连通性学习笔记. 注意一些写法上的问题. line37&line61:因为引用,所以j和head值是同步更新的,类似于网络流的当前弧优化,除了优化枚举外,这样 ...

  7. 【UOJ117】 欧拉回路(欧拉回路)

    传送门 UOJ Solution 无解 t=1,无向图,当且仅当\(\exists i \ \ in_i \ne out_i\) t=2,有向图,当且仅当\(\exists i \ \ in_i是奇数 ...

  8. ACM/ICPC 之 混合图的欧拉回路判定-网络流(POJ1637)

    //网络流判定混合图欧拉回路 //通过网络流使得各点的出入度相同则possible,否则impossible //残留网络的权值为可改变方向的次数,即n个双向边则有n次 //Time:157Ms Me ...

  9. [poj2337]求字典序最小欧拉回路

    注意:找出一条欧拉回路,与判定这个图能不能一笔联通...是不同的概念 c++奇怪的编译规则...生不如死啊... string怎么用啊...cincout来救? 可以直接.length()我也是长见识 ...

随机推荐

  1. 【BZOJ】2440: [中山市选2011]完全平方数

    [题意]T次询问第k小的非完全平方数倍数的数.T<=50,k<=10^9.(即无平方因子数——素因数指数皆为0或1的数) [算法]数论(莫比乌斯函数) [题解]考虑二分,转化为询问[1,x ...

  2. 【NOIP】提高组2014

    Day1 T1(暴力):大水题 #include<cstdio> ][]={ ,,,,, ,,,,, ,,,,, ,,,,, ,,,,, }; ],b[]; int main() { in ...

  3. WordPress浏览数插件的安装使用

    插件安装很容易,但是和大多插件都一样,安装后需要调用代码才能显示,我安装后,也调用了.但是就是不显示,后来才发现,我从其他地方复制过来的代码,函数是中文的单引号,这样致使函数失效,注意代码中参数的引号 ...

  4. perl6 HTTP::UserAgent (3) JSON

    如果一个 URL 要求POST数据是 JSON格式的, 那我们要怎么发送数据呢? 第一种: HTTP::Request 上一篇说到, 发送 POST 数据, 可以: . $ua.post(url, % ...

  5. ubuntu下中文输入法的配置,建议用fcitx

    Fcitx [ˈfaɪtɪks] 是一个支持扩展的输入法框架.它有自己维护的三个输入法,拼音,区位和码表:还支持其他引擎,rime 中州韵,google-pinyin,sunpinyin.Fcitx ...

  6. 002利用zabbix监控某个目录大小

    近期,因为JMS的消息堆积导致ApacheMQ频率故障(消息没有被消费掉,导致其数据库达到1.2G,JMS此时直接挂掉),很是郁闷!刚好自 己在研究zabbix.既然zabbix如此强大,那么它可以监 ...

  7. 模块定义文件.def

    一作用 DLL中导出函数的声明有两种方式:一种为在函数声明中加上__declspec(dllexport),这里不再举例说明:另外一种方式是采用模块定义(.def) 文件声明,.def文件为链接器提供 ...

  8. v4l

    v4l 2011-11-08 11:01:54|  分类: 默认分类|举报|字号 订阅     第一个部分介绍一些v4l的基本概念和基本方法,利用系统API完成一系列函数以方便后续应用程序的开发和使用 ...

  9. Java显式锁学习总结之四:ReentrantLock源码分析

    概述 ReentrantLock,即重入锁,是一个和synchronized关键字等价的,支持线程重入的互斥锁.只是在synchronized已有功能基础上添加了一些扩展功能. 除了支持可中断获取锁. ...

  10. javascript当中的this详解

    总结this的3个规则: this是调用上下文,上下文被创建或者初始化时才确定 非严格模式:this是全局对象:严格模式:this是undefined 函数调用 a. 以函数形式调用的函数通常不使用t ...