[UVA 10054]The Necklace[欧拉回路][打印路径]

题目链接: [UVA 10054]The Necklace[欧拉回路][打印路径]

题意分析:

判断图中是否都是欧拉回路,是的话输出所有路径。

解题思路:

根据所有点的度数来判断是否是欧拉回路,当所有点的度数都是偶数时,该图即都为欧拉回路。因为这题可能存在多个回路,所以不用判连通。

个人感受:

嘛,不会做呀。多做多练。

具体代码如下:

#include<iostream>
#include<cctype>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<set>
#include<queue>
using namespace std;
const int INF = 0x7f7f7f7f, MAXN = 111;
int c[MAXN], g[MAXN], vis[MAXN][MAXN];
vector<int> v[MAXN];

void euler(int u)
{
    for (int i = 0; i < v[u].size(); ++i)
    {
        int cur = v[u][i];
        if (vis[u][cur])
        {
            --vis[u][cur]; --vis[cur][u];
            euler(cur);
            printf("%d %d\n", cur, u);
        }
    }
}

int main()
{
    int t, n, a, b;
    for (int kase = scanf("%d", &t); kase <= t; ++kase)
    {
        memset(vis, 0, sizeof vis);
        for (int i = 0; i < MAXN; ++i) v[i].clear(), g[i] = 0;
        if (kase > 1) printf("\n");
        scanf("%d", &n);
        set<int> color;
        for (int i = 0; i < n; ++i)
        {
            scanf("%d %d", &a, &b);
            color.insert(a); color.insert(b);
            v[a].push_back(b); v[b].push_back(a);
            ++g[a], ++g[b];
            ++vis[a][b], ++vis[b][a];
        }
        bool flag = 0;
        for (auto it = color.begin(); it != color.end(); ++it)
        {
            if (g[*it] % 2)
            {
                flag = 1;
                break;
            }
        }
        printf("Case #%d\n", kase);
        if (flag) cout << "some beads may be lost\n";
        else
        {
            euler(*color.begin());
        }
    }
    return 0;
}


你可能感兴趣的:(图论,uva,欧拉回路)