图论——欧拉路径

一、定义

1.基本概念

欧拉路径: 图G中的一条路径,能够通过图中的每一条边,并且每条边仅通过一次
欧拉回路: 就是闭合的欧拉路径
欧拉图: 包含欧拉回路的图

2.判断

有向图:

  • 欧拉路径:有一个点出度比入度多1(起点),有一个点入度比出度多1(终点),其余点出度等于入度;
  • 欧拉回路:每个顶点出度等于入度;

无向图:

  • 欧拉路径:有且仅有两个点的入度为1,分别是起点和终点;
  • 欧拉回路:图中所有顶点的度数都是偶数,并且该图是连通图;

二、例题

1.一笔画问题
问题描述:
如果一个图存在一笔画,则一笔画的路径叫做欧拉路,如果最后又回到起点,那这个路径叫做欧拉回路。
根据一笔画的两个定理,如果寻找欧拉回路,对任意一个点执行深度优先遍历;找欧拉路,则对一个奇点执行 d f s dfs dfs,时间复杂度为 O ( m + n ) O(m+n) O(m+n) m m m为边数, n n n是点数。

输入
第一行 n , m n,m nm,有 n n n个点, m m m条边,以下 m m m行描述每条边连接的两点。

输出
欧拉路或欧拉回路,输出一条路径即可。

样例输入

5 5
1 2
2 3
3 4
4 5
5 1

样例输出

1 5 4 3 2 1

策略分析:

建图、存度数,然后dfs,同时记录路径即可

代码

#include <iostream>
#define MAXN 10005
using namespace std;
bool g[MAXN][MAXN]; 
int n, m, ans[MAXN], dep[MAXN], cnt;

void dfs(int v) {
	for(int i = 1; i <= n; i++) {
		if(g[v][i]) {
			g[v][i] = g[i][v] = 0;
			dfs(i);
		}
	}
	ans[++cnt] = v;
} 

int main() {
	ios::sync_with_stdio(0);
	int u, v, s = -1;
	cin >> n >> m;
	for(int i = 1; i <= m; i++) {
		cin >> u >> v;
		g[u][v] = g[v][u] = 1;
		dep[v]++, dep[u]++;
	}
	for(int i = 1; i <= n; i++)  //找到起点
		if(dep[i] % 2 == 1) 
			s = i;
	if(s == -1) s = 1;
	dfs(s);
	for(int i = 1; i <= cnt; i++) 
		cout << ans[i] << " "; 
	return 0;	
}
  • 3
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值