HDU1878(欧拉回路)
程序员文章站
2023-12-23 15:48:28
...
HDU1878
简单图论问题,欧拉路问题可以用并查集或者dfs判断连通性。在统计度数即可判断,但是这种值针对纯无向图或者纯有向图。两者混合判断不了,需要使用Dinic等算法。
欧拉回路
- 有向图欧拉回路,分别统计每个点的出度与入度,所有的点是一个连通集,并且所有点的出度与入度相同。
2.无向图欧拉回路,统计每个点的度即可,所有的点是一个连通集并且所有的点的度数都是偶数。
欧拉通路
-
有向图欧拉通路,分别统计每个点的出度为+1与入度为-1,所有的点是一个连通集,入度与出度加和有且只有一个点的度为1,一个点的度为-1,那么度为1的是起点,度为-1的为终点。
-
无向图欧拉回路,统计每个点的度即可,所有的点是一个连通集并且所有的点的出度与入度加和都是0。
#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <queue>
using namespace std;
int s[1005];
int a[1005];
inline void clear_set()
{
for(int i = 1;i < 1005;i++){
s[i] = i;
}
memset(a,0,sizeof(a));
}
inline int find_set(int x)
{
if(x != s[x]){
s[x] = find_set(s[x]);
}
return s[x];
}
inline void union_set(int x,int y)
{
x = find_set(x);
y = find_set(y);
if(x != y){
s[x] = y;
}
}
int main()
{
int n,m;
while(~scanf("%d",&n) && n){
clear_set();
scanf("%d",&m);
while(m--){
int x,y;
scanf("%d%d",&x,&y);
a[x]++;a[y]++;
union_set(x,y);
}
int cnt = 0,res = 0;
for(int i = 1;i <= n;i++){
if(a[i]%2 == 1){ //统计奇数度点
cnt++;
break;
}
if(find_set(i) == i){ //统计根节点数目
res++;
}
}
if(cnt == 0 && res == 1){ //全是偶点,只有一个根
printf("1\n");
}
else{
printf("0\n");
}
}
return 0;
}
愿你走出半生,归来仍是少年~
推荐阅读
-
HDU 1956 “Sightseeing Tour“ (混合欧拉回路)
-
杭电多校第二场 1003 HDU-6311 Cover(欧拉回路)
-
HDU1878(欧拉回路)
-
世界最美的十大公式 欧拉公式变换无穷,你能发现它们的美吗
-
图论小结(一)包括一些最短路,最小生成树,差分约束,欧拉回路,的经典题和变种题。强连通,双连通,割点割桥的应用。二分匹配
-
欧仁·德拉克罗瓦代表作品有哪些?对社会有着什么影响
-
BZOJ4804: 欧拉心算(莫比乌斯反演 线性筛)
-
世界最美的十大公式 欧拉公式变换无穷,你能发现它们的美吗
-
BZOJ3288: Mato矩阵(欧拉函数 高斯消元)
-
poj1637 Sightseeing tour(混合图欧拉回路)