zoukankan      html  css  js  c++  java
  • POJ 2513 Colored Sticks

    问一个无向图是否存在欧拉路径。

    条件:在无向图中,奇度点为2,其余都为偶度点。

    端点有字典树处理即可。

    #include <iostream>
    #include <cstdlib>
    #include <cstdio>
    #include <string>
    #include <cstring>
    #include <cmath>
    #include <vector>
    #include <queue>
    #include <algorithm>
    #include <map>
    using namespace std;
    
    const int maxn = 500010;
    
    int n, m;
    
    int fa[maxn];
    int ind[maxn];
    int outd[maxn];
    bool vis[maxn];
    
    int find(int x)
    {
        return x == fa[x]? x : fa[x] = find(fa[x]);
    }
    
    void Union(int x, int y)
    {
        x = find(x), y = find(y);
        if(x == y) return ;
        fa[x] = y;
    }
    
    void init()
    {
        memset(ind, 0, sizeof(ind));
        memset(outd, 0, sizeof(outd));
        memset(vis, 0, sizeof(vis));
        for(int i = 1; i < maxn; i++) fa[i] = i;
    }
    
    void readint(int &x)
    {
        char c;
        while(!isdigit(c)) c = getchar();
        
        x = 0;
        while(isdigit(c))
        {
            x = x*10 + c-'0';
            c = getchar();
        }
    }
    
    void writeint(int x)
    {
        if(x > 9) writeint(x/10);
        putchar(x%10+'0');
    }
    
    int check()
    {
        int count = 0;
        for(int i = 1; i <= n; i++) if(vis[i] && fa[i] == i) count++;
        if(count > 1) return 0;
        
        int c1 = 0;
        for(int i = 1; i <= n; i++) if(vis[i])
        {
            if((ind[i]+outd[i]) & 1) c1++;
        }
        if(c1 == 2 || c1 == 0) return 1;
        return 0;
    }
    
    const int maxnode = 500010;
    const int sigma_size = 26;
    
    struct Trie
    {
        int ch[maxnode][sigma_size];
        int val[maxnode];
        int sz;
        int v;
        void init() { sz = 1; v = 0; memset(ch[0], 0, sizeof(ch[0])); }
        int idx(char c) { return c-'a'; }
        
        int insert(char *s)
        {
            int u = 0, n = strlen(s);
            for(int i = 0; i < n; i++)
            {
                int c = idx(s[i]);
                if(!ch[u][c])
                {
                    memset(ch[sz], 0, sizeof(ch[sz]));
                    val[sz] = 0;
                    ch[u][c] = sz++;
                }
                u = ch[u][c];
            }
            if(val[u] != 0) return val[u];
            else
            {
                val[u] = ++v;
                return v;
            }
        }
    }trie;
    
    int main()
    {
        int T = 0;
        init();
        trie.init();
        
        char s1[20], s2[20];
        while(~scanf("%s%s", &s1, &s2))
        {
            int x = trie.insert(s1), y = trie.insert(s2);
            vis[x] = vis[y] = 1;
            outd[x]++, ind[y]++;
            Union(x, y);
            T++;
        }
        n = trie.v;
        if(T == 0) { printf("Possible
    "); return 0; }
        if(check()) printf("Possible
    ");
        else printf("Impossible
    ");
    }
    View Code
  • 相关阅读:
    阿里云云计算认证ACP模拟考试练习题10套:第1套模拟题分享
    as3+java+mysql(mybatis) 数据自动工具(二)
    自动化登录账号密码并截图保存
    自动化读取csv文件
    自动化读取磁盘文件并逐一在百度上面进行搜索
    自动化打开百度搜索
    python自动化--数据驱动(从文件中提取)
    pycharm 命令行方式
    软件测试工程师 总结
    八大元素定位代码
  • 原文地址:https://www.cnblogs.com/Buck-Meister/p/3237252.html
Copyright © 2011-2022 走看看