经典好题,自己不知道哪里错了交上去是RE,可能是数组开的不好吧,字典树老碰到这种问题。。

先马上别人的代码,有空对拍看看

#include <cstdio>
#include <cstring>
int const MAX = ;
int fa[MAX], d[MAX], cnt; struct Trie
{
int sz, t[MAX][];
int jud[MAX];
Trie()
{
sz = ;
memset(t[], -, sizeof(t));
jud[] = ;
}
void clear()
{
sz = ;
memset(t[], -, sizeof(t));
jud[] = ;
}
int idx(char c)
{
return c - 'a';
}
void insert(char* s, int v)
{
int u = , len = strlen(s);
for(int i = ; i < len; i++)
{
int c = idx(s[i]);
if(t[u][c] == -)
{
memset(t[sz], -, sizeof(t[sz]));
jud[sz] = ;
t[u][c] = sz++;
}
u = t[u][c];
}
jud[u] = v;
}
int search(char* s)
{
int u = , len = strlen(s);
for(int i = ; i < len; i++)
{
int c = idx(s[i]);
if(t[u][c] == -)
return -;
u = t[u][c];
}
if(jud[u])
return jud[u];
return -;
}
}t; void Init()
{
for(int i = ; i < MAX; i++)
fa[i] = i;
} int Find(int x)
{
return x == fa[x] ? x : fa[x] = Find(fa[x]);
} void Union(int a, int b)
{
int r1 = Find(a);
int r2 = Find(b);
if(r1 != r2)
fa[r1] = r2;
} bool eluer()
{
int sum = , t = -;
for(int i = ; i < cnt; i++)
if(d[i] % )
sum++;
if(sum != && sum != )
return false;
for(int i = ; i < cnt; i++)
{
if(t == -)
t = Find(i);
else if(Find(i) != Find(t))
return false;
}
return true;
} int main()
{
char s1[],s2[];
cnt = ;
Init();
t.clear();
while(scanf("%s %s", s1, s2) != EOF)
{
if(t.search(s1) == -)
t.insert(s1, cnt++);
int u = t.search(s1);
if(t.search(s2) == -)
t.insert(s2, cnt++);
int v = t.search(s2);
Union(u, v);
d[u]++;
d[v]++;
}
if(eluer())
printf("Possible\n");
else
printf("Impossible\n");
}

下面是RE代码

/*
1 2
2 3
4 1
1 5
5 4
1 5,5 4,4 1,1 2,2 3
数据量大,不能用map
建立字典树,保留每个颜色的id
更新每个颜色的度,只要一个颜色的度为奇数,cnt1++
用并查集保存图的连通性,如果最后剩下两个集,那么图不连通
注意:每个颜色都是一个点,每根木棒连接两个颜色,这就可以看做是并查集的连接
500*26
*/
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
struct Trie{
int next[][];
int id[];
int root,L,cnt;
int newnode(){
for(int i=;i<;i++)
next[L][i]=-;
id[L]=;
return L++;
}
void init(){
L=cnt=;
root=newnode();
}
int insert(char s[]){
//cout << s << cnt<<endl;
int len=strlen(s);
int now=root;
for(int i=;i<len;i++){
if(next[now][s[i]-'a']==-)
next[now][s[i]-'a']=newnode();
now=next[now][s[i]-'a'];
}
if(id[now]==)
id[now]=++cnt;
return id[now];
}
}tr;
int degree[*];
int F[*];
int find(int x){
if(F[x]==-) return x;
return F[x]=find(F[x]);
}
void bing(int a,int b){
int t1=find(a);
int t2=find(b);
if(t1!=t2) F[t1]=t2;
}
int main(){
tr.init();
memset(degree,,sizeof degree);
memset(F,-,sizeof F);
char s1[],s2[];
while(scanf("%s%s",s1,s2)!=EOF){
int id1=tr.insert(s1);
int id2=tr.insert(s2);
degree[id1]++;
degree[id2]++;
bing(id1,id2);
}
int cnt1=,cnt2=;//度为奇数的颜色,联通块
for(int i=;i<=tr.cnt;i++){
if(degree[i]%==) cnt1++;
if(F[i]==-) cnt2++;
if(cnt1>) break;
if(cnt2>) break;
} if ((cnt2== || cnt2==) && (cnt1== || cnt1==))
puts("Possible");
else puts("Impossible");
return ;
}

poj2513--并查集+欧拉路+字典树的更多相关文章

  1. Colored Sticks (字典树哈希+并查集+欧拉路)

    Time Limit: 5000MS   Memory Limit: 128000K Total Submissions: 27704   Accepted: 7336 Description You ...

  2. poj 2513 Colored Sticks (trie树+并查集+欧拉路)

    Colored Sticks Time Limit: 5000MS   Memory Limit: 128000K Total Submissions: 40043   Accepted: 10406 ...

  3. NYOJ--42--dfs水过||并查集+欧拉通路--一笔画问题

    dfs水过: /* Name: NYOJ--42--一笔画问题 Author: shen_渊 Date: 18/04/17 15:22 Description: 这个题用并查集做,更好.在练搜索,试试 ...

  4. 【bzoj4399】魔法少女LJJ 并查集+权值线段树合并

    题目描述 在森林中见过会动的树,在沙漠中见过会动的仙人掌过后,魔法少女LJJ已经觉得自己见过世界上的所有稀奇古怪的事情了LJJ感叹道“这里真是个迷人的绿色世界,空气清新.淡雅,到处散发着醉人的奶浆味: ...

  5. Colored Sticks POJ - 2513 并查集+欧拉通路+字典树hash

    题意:给出很多很多很多很多个棒子 左右各有颜色(给出的是单词) 相同颜色的可以接在一起,问是否存在一种 方法可以使得所以棒子连在一起 思路:就是一个判欧拉通路的题目,欧拉通路存在:没奇度顶点   或者 ...

  6. POJ2513 欧拉 + 字典树

    POJ 2513 有N根木棒,一根木棒有2头,我们把每头涂色(相同或不同),如果2根木棒有相同颜色的一端就可以连接,颜色全部不同就不能连接,现在给你N根木棒以及它们的颜色,问最后能不能链接成1条链. ...

  7. 【BZOJ-3673&3674】可持久化并查集 可持久化线段树 + 并查集

    3673: 可持久化并查集 by zky Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 1878  Solved: 846[Submit][Status ...

  8. POJ 2513 Colored Sticks (离散化+并查集+欧拉通路)

    下面两个写得很清楚了,就不在赘述. http://blog.sina.com.cn/s/blog_5cd4cccf0100apd1.htmlhttp://www.cnblogs.com/lyy2890 ...

  9. 牛客练习赛40 C 小A与欧拉路(树的直径)

    链接:https://ac.nowcoder.com/acm/contest/369/C 题目描述 小A给你了一棵树,对于这棵树上的每一条边,你都可以将它复制任意(可以为0)次(即在这条边连接的两个点 ...

随机推荐

  1. Windows 7 SP1无人值守自动应答文件制作

    使用U盘安装Windows系统时,很多人都会使用UltraISO工具来制作U盘启动盘,然后插入到电脑中加以安装.系统的安装过程中,需要一步一步手动选择或者输入配置,Windows是支持无人值守自动应答 ...

  2. requirements.txt文件教程

    方法有2种,命令都是一样,只是执行地方不一样 此方法主要用于迁移新环境使用,为防止代码出现问题,最好使用原装库,所以就有了迁移代码和库的操作 第一种:在pycharm中,左下角有个双重正方形,点击里面 ...

  3. const关键字的作用

    1.防止被修饰的成员的内容被改变. 2.修饰类的成员函数时,表示其为一个常函数,意味着成员函数将不能修改类成员变量的值. 3.在函数声明时修饰参数,表示在函数访问时参数(包括指针和实参)的值不会发生变 ...

  4. python,关于这个里边的私有方法(private)、保护方法(protected)、公开方法(public)

    __foo__: 定义的是特殊方法,一般是系统定义名字 ,类似 __init__() 之类的. _foo: 以单下划线开头的表示的是 protected 类型的变量,即保护类型只能允许其本身与子类进行 ...

  5. 2017-2018-2 20165325 实验二《Java面向对象程序设计》实验报告

    一.面向对象程序设计-1 1.检查点要求 参考 http://www.cnblogs.com/rocedu/p/6371315.html#SECUNITTEST 参考 http://www.cnblo ...

  6. Linux下查询文件的md5,sha1值

    验证下载下来的文件包是不是一致 ··· 验证md5值 #md5sum filename 验证shal值 #sha1sum filename ···

  7. 【ARTS】01_16_左耳听风-20190225~20190303

    ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...

  8. 817. Linked List Components

    1. 原始题目 We are given head, the head node of a linked list containing unique integer values. We are a ...

  9. javascript动态的改变checkbox的选中状态

    <td> <div class="checkbox"> <label> <input type="checkbox" ...

  10. 解决“错误 D8016 “/ZI”和“/Gy-”命令行选项不兼容 ”问题

    在Visual Studio 2017中调试VC++6.0代码,出现该问题,解决方案如下:(1)[项目]—>[属性]—>[C/C++]—> [常规]—>[调试信息格式]—> ...