poj2513--并查集+欧拉路+字典树
经典好题,自己不知道哪里错了交上去是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--并查集+欧拉路+字典树的更多相关文章
- Colored Sticks (字典树哈希+并查集+欧拉路)
Time Limit: 5000MS Memory Limit: 128000K Total Submissions: 27704 Accepted: 7336 Description You ...
- poj 2513 Colored Sticks (trie树+并查集+欧拉路)
Colored Sticks Time Limit: 5000MS Memory Limit: 128000K Total Submissions: 40043 Accepted: 10406 ...
- NYOJ--42--dfs水过||并查集+欧拉通路--一笔画问题
dfs水过: /* Name: NYOJ--42--一笔画问题 Author: shen_渊 Date: 18/04/17 15:22 Description: 这个题用并查集做,更好.在练搜索,试试 ...
- 【bzoj4399】魔法少女LJJ 并查集+权值线段树合并
题目描述 在森林中见过会动的树,在沙漠中见过会动的仙人掌过后,魔法少女LJJ已经觉得自己见过世界上的所有稀奇古怪的事情了LJJ感叹道“这里真是个迷人的绿色世界,空气清新.淡雅,到处散发着醉人的奶浆味: ...
- Colored Sticks POJ - 2513 并查集+欧拉通路+字典树hash
题意:给出很多很多很多很多个棒子 左右各有颜色(给出的是单词) 相同颜色的可以接在一起,问是否存在一种 方法可以使得所以棒子连在一起 思路:就是一个判欧拉通路的题目,欧拉通路存在:没奇度顶点 或者 ...
- POJ2513 欧拉 + 字典树
POJ 2513 有N根木棒,一根木棒有2头,我们把每头涂色(相同或不同),如果2根木棒有相同颜色的一端就可以连接,颜色全部不同就不能连接,现在给你N根木棒以及它们的颜色,问最后能不能链接成1条链. ...
- 【BZOJ-3673&3674】可持久化并查集 可持久化线段树 + 并查集
3673: 可持久化并查集 by zky Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 1878 Solved: 846[Submit][Status ...
- POJ 2513 Colored Sticks (离散化+并查集+欧拉通路)
下面两个写得很清楚了,就不在赘述. http://blog.sina.com.cn/s/blog_5cd4cccf0100apd1.htmlhttp://www.cnblogs.com/lyy2890 ...
- 牛客练习赛40 C 小A与欧拉路(树的直径)
链接:https://ac.nowcoder.com/acm/contest/369/C 题目描述 小A给你了一棵树,对于这棵树上的每一条边,你都可以将它复制任意(可以为0)次(即在这条边连接的两个点 ...
随机推荐
- MySQL基本命令(待更新...)
数据库操作SQL语句 show databases; 表操作SQL语句 数据库权限操作SQL语句 参考链接 :http://www.cnblogs.com/bzys/archive/2013/01/2 ...
- es教程
概念 关系数据库 ⇒ 数据库 ⇒ 表 ⇒ 行 ⇒ 列(Columns) Elasticsearch ⇒ 索引(Index) ⇒ 类型(type) ⇒ 文档(Docments) ⇒ 字段(Fields) ...
- package-lock.json和package.json区别
package.json里面定义的是版本范围(比如^1.0.0),具体跑npm install的时候安的什么版本,要解析后才能决定,这里面定义的依赖关系树,可以称之为逻辑树(logical tree) ...
- Gradle的使用
⒈下载 点击此处 ⒉安装 1.解压 2.添加环境变量GRADLE_HOME 指向解压缩文件的磁盘地址 3.PATH环境变量添加%GRADLE_HOME%\bin ⒊使用阿里云仓库 repositori ...
- 【转】python 退出程序的方式
[转]python 退出程序的方式 python程序退出方式[sys.exit() os._exit() os.kill() os.popen(...)] 知乎说明 http://www.zhihu. ...
- 【转】MySQL— 进阶
[转]MySQL— 进阶 目录 一.视图 二.触发器 三.函数 四.存储过程 五.事务 一.视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需 ...
- 【转】MySQL-Select语句高级应用
[转]MySQL-Select语句高级应用 1.1 SELECT高级应用 1.1.1 前期准备工作 本次测试使用的是world数据库,由mysql官方提供下载地址: https://dev.mysql ...
- Python调用subprocess.Popen卡死的解决方案
转载自:https://www.cnblogs.com/keke-xiaoxiami/p/7875009.html 在Python中,调用:subprocess.Popen(cmd, stdout = ...
- wtforms-表单生成及验证
介绍 wtforms是一个支持多个web框架的form组件,主要用来做表单的验证以及生成的, 安装 pip install wtforms 使用 自定义一个类,继承wtforms.Form类,定义字段 ...
- python中input和raw_input函数
python input() 相等于 eval(raw_input(prompt)) ,用来获取控制台的输入. raw_input() 将所有输入作为字符串看待,返回字符串类型.而 input() 在 ...