码迷,mamicode.com
首页 > 其他好文 > 详细

欧拉回路与欧拉路径

时间:2018-03-01 11:41:48      阅读:165      评论:0      收藏:0      [点我收藏+]

标签:超过   问题   并查集   时间复杂度   补充   png   成功   集成   log   

欧拉回路与欧拉路径

如果图G中的一个路径包括每个边恰好一次,则该路径称为欧拉路径(欧拉通路)。

如果一个回路是欧拉路径,则称为欧拉回路(Euler circuit)。

说的直白点,欧拉回路就是从一个点出发,经过每一条边恰好一次,最后能回到这个点的路径

例如下图中的红色路径组成了一个欧拉回路
技术分享图片

存在条件

欧拉回路的充要条件

  • 无向图:所有点的度数都为偶数

  • 有向图:所有点的入度都等于出度

欧拉路径的充要条件

  • 无向图:除两点(起点与终点)外其余所有点的度数都为偶数

  • 有向图:除两点(起点入度\(+1\)=出度,终点入度\(-1\)等于出度)外,其余所有点的入度等于出度

判断方法

利用并查集判断

若给出的图满足欧拉回路/欧拉路径的重要条件且并查集成功合并的 次数\(>=\)点数\(-1\),则证明含有欧拉回路/欧拉路径

欧拉路径:洛谷P1333

欧拉回路:HDU 1878

dfs

如果要求输出方案,那么只能用dfs

UOJ 117

拓展

这里再补充一种两笔画问题

解决方法比较简单

有解当且仅当度数为奇数的点不超过4个。

将其中两个点加一条边后求欧拉路径,在这条边处断开变成两条路径即可。

时间复杂度\(O(m)\)

欧拉回路与欧拉路径

标签:超过   问题   并查集   时间复杂度   补充   png   成功   集成   log   

原文地址:https://www.cnblogs.com/zwfymqz/p/8486697.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!