zoukankan      html  css  js  c++  java
  • POJ2513 Colored Sticks (并查集+trie)

    Colored Sticks
    Time Limit: 5000MS   Memory Limit: 128000K
         

    Description

    You are given a bunch of wooden sticks. Each endpoint of each stick is colored with some color. Is it possible to align the sticks in a straight line such that the colors of the endpoints that touch are of the same color?

    Input

    Input is a sequence of lines, each line contains two words, separated by spaces, giving the colors of the endpoints of one stick. A word is a sequence of lowercase letters no longer than 10 characters. There is no more than 250000 sticks.

    Output

    If the sticks can be aligned in the desired way, output a single line saying Possible, otherwise output Impossible.

    Sample Input

    blue red
    red violet
    cyan blue
    blue magenta
    magenta cyan
    

    Sample Output

    Possible

    Hint

    Huge input,scanf is recommended.

    Source

     
    回顾了一下欧拉图的知识。。整个图的奇度点个数如果>=3或只有1个 就不能一笔画画完
    中间re了几次。。因为trie里我开了n*30,但是外面数组只开了n...
     1 #include<set>
     2 #include<queue>
     3 #include<cstdio>
     4 #include<cstdlib>
     5 #include<cstring>
     6 #include<iostream>
     7 #include<algorithm>
     8 using namespace std;
     9 const int N = 250010;
    10 #define For(i,n) for(int i=1;i<=n;i++)
    11 #define For0(i,n) for(int i=0;i<n;i++)
    12 #define Rep(i,l,r) for(int i=l;i<=r;i++)
    13 
    14 char s1[11],s2[11];
    15 int n,in[N*30],fa[N*30],ans;
    16 struct Trie{
    17     int sz,ch[N*30][26],v[N*30],Loc[N*30];
    18     Trie(){sz=1;}
    19     int insert(char st[]){
    20         int now=1;v[1]++;int len=strlen(st);
    21         For0(i,len){
    22             int id=st[i]-'a';
    23             if(!ch[now][id]) ch[now][id]=++sz;
    24             v[now=ch[now][id]]++;
    25         }
    26         if(Loc[now]) return Loc[now];
    27         else         return Loc[now]=++n;
    28     }
    29 }trie;
    30 
    31 int find(int i){
    32     if(fa[i]==i) return i;
    33     else         return fa[i]=find(fa[i]);
    34 }
    35 
    36 int main(){
    37     #ifndef ONLINE_JUDGE
    38         freopen("trie.in","r",stdin);
    39     #endif // ONLINE_JUDGE
    40     For0(i,N*30) fa[i]=i;
    41     while(scanf("%s %s",&s1,&s2)!=EOF){
    42         int x=trie.insert(s1),y=trie.insert(s2);
    43         in[x]++;in[y]++;
    44         int fx=find(x),fy=find(y);
    45         if(fx!=fy) fa[fx]=fy;
    46     }
    47     int checks=find(1);
    48     Rep(i,2,n) if(find(i)!=checks){
    49         puts("Impossible
    ");
    50         return 0;
    51     }
    52     For(i,n) {
    53         in[i]=in[i]%2;
    54         if(in[i]) ans++;
    55     }
    56     if(ans==1||ans>=3) puts("Impossible");
    57     else               puts("Possible");
    58     return 0;
    59 }
  • 相关阅读:
    kafka的概念
    java的多线程:java安全问题产生的原因与JMM的关系
    java的多线程:线程安全问题
    web自动化之键盘操作
    获取cookie里面的sessionid
    Python连接mysql数据库
    Python 发送Email
    Python日志模块
    openxl模块从excel里面读取数据
    Python读取配置文件
  • 原文地址:https://www.cnblogs.com/zjdx1998/p/3971446.html
Copyright © 2011-2022 走看看