poj2513Colored Sticks(无向图的欧拉回路)
/*
题意:将两端涂有颜色的木棒连在一起,并且连接处的颜色相同!
思路:将每一个单词看成一个节点,建立节点之间的无向图!判断是否是欧拉回路或者是欧拉路 并查集判通 + 奇度节点个数等于2或者0
*/
#include<cstring>
#include<cstdio>
#include<algorithm>
#define N 2500005*2
using namespace std; int f[N];
int trie[N][];
int rank[N];
int deg[N]; int getFather(int x){
return x==f[x] ? x : f[x]=getFather(f[x]);
} void Union(int a, int b){
int fa=getFather(a), fb=getFather(b);
if(fa!=fb){
if(rank[fa]>rank[fb]){
rank[fa]+=rank[fb]+;
f[fb]=fa;
}
else{
f[fa]=fb;
rank[fb]+=rank[fa]+;
}
}
} int main(){
int cnt=, c=, cur=;
int u, v;
char ch[];
for(int i=; i<N; ++i)
f[i]=i;
while(scanf("%s", ch)!=EOF){
++c;
cur=;
for(int i=; ch[i]; ++i){
if(!trie[cur][ch[i]-'a'])
trie[cur][ch[i]-'a']=++cnt;
cur=trie[cur][ch[i]-'a'];
}
if(c&) u=cur;
else v=cur; if((c&)==){
Union(u, v);
++deg[u];
++deg[v];
}
}
int rootN=, degN=;
for(int i=; i<=cnt; ++i){
if(deg[i] && f[i]==i) ++rootN;
if(deg[i]&) ++degN;
if(rootN> || degN>) break;
}
if(rootN== && (degN== || degN==) || rootN== && degN==)
printf("Possible\n");
else printf("Impossible\n");
return ;
}
poj2513Colored Sticks(无向图的欧拉回路)的更多相关文章
- POJ2513——Colored Sticks(Trie树+欧拉回路+并查集)
		
Colored Sticks DescriptionYou are given a bunch of wooden sticks. Each endpoint of each stick is col ...
 - hdu 1878 无向图的欧拉回路
		
原题链接 hdu1878 大致题意: 欧拉回路是指不令笔离开纸面,可画过图中每条边仅一次,且可以回到起点的一条回路.现给定一个无向图,问是否存在欧拉回路? 思路: 无向图存在欧拉回路的条件:1.图是连 ...
 - SGU---101 无向图的欧拉回路
		
题目链接: https://cn.vjudge.net/problem/SGU-101 题目大意: 给定你n张骨牌,每张牌左右两端有一个数字,每张牌的左右两端数字可以颠倒,找出一种摆放骨牌的顺序,使得 ...
 - UVA 10054 The Necklace (无向图的欧拉回路)
		
本文链接:http://www.cnblogs.com/Ash-ly/p/5405904.html 题意: 妹妹有一条项链,这条项链由许多珠子串在一起组成,珠子是彩色的,两个连续的珠子的交汇点颜色相同 ...
 - POJ2513Colored Sticks
		
http://poj.org/problem?id=2513 题意 : 一些木棒,两端都涂上颜色,求是否能将木棒首尾相接,连成一条直线,要求不同木棒相接的一边必须是相同颜色的. 思路 : 这个题的话就 ...
 - 算法笔记_143:构造无向图的欧拉回路(Java)
		
目录 1 问题描述 2 解决方案 1 问题描述 具体链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Item ...
 - 算法笔记_142:无向图的欧拉回路求解(Java)
		
目录 1 问题描述 2 解决方案 1 问题描述 John's trip Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8 ...
 - 算法笔记_141:无向图的欧拉回路判断问题(Java)
		
目录 1 问题描述 2 解决方案 1 问题描述 Problem Description 欧拉回路是指不令笔离开纸面,可画过图中每条边仅一次,且可以回到起点的一条回路.现给定一个图,问是否存在欧拉回 ...
 - HDU 1878  欧拉回路(无向图的欧拉回路)
		
欧拉回路 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
 
随机推荐
- [转] How to change font settings for all UI elements (toolbar and context menus, property editors, etc.)
			
https://www.devexpress.com/Support/Center/Question/Details/S35762
 - 技术文档--studio技术文档
			
1.Google推出的毫无疑问,这个是它的最大优势,Android Stuido是Google推出,专门为Android“量身订做”的,是Google大力支持的一款基于IntelliJ IDEA改造的 ...
 - C++混合编程之idlcpp教程Python篇(9)
			
上一篇在这 C++混合编程之idlcpp教程Python篇(8) 第一篇在这 C++混合编程之idlcpp教程(一) 与前面的工程相比,工程PythonTutorial7中除了四个文件PythonTu ...
 - 分享:写了一个 java 调用 C语言 开发的动态库的范例
			
分享:写了一个 java 调用 C语言 开发的动态库的范例 cfunction.h 代码#pragma once#ifdef __cplusplusextern "C" {#e ...
 - 奇妙的动态代理:EF中返回的对象为什么序列化失败
			
今天有如鹏的学生遇到一个问题:把一个对象保存到Session中(进程外Session)后,Web服务器重启,当从Session读取这个对象的时候报错,提示是一个“T_Users”后面跟着一大串数字的类 ...
 - java 多线程(synchronized)
			
package com.example; public class App { public static void main(String[] args) { doRunable dr = new ...
 - 【吉光片羽】js横向滚动与浮动导航
			
1.横向滚动,这个方法是见过最简洁的了. #demo { background: #FFF; overflow: hidden; border: 1px dashed #CCC; width: 117 ...
 - 用 C 扩展 python
			
本文介绍如何用 C 语言来扩展 python.所举的例子是,为 python 添加一个设置字符串到 windows 的剪切板(Clipboard)的功能.我在写以下代码的时候用到的环境是:window ...
 - Linux 比较判断运算(if test)
			
200 ? "200px" : this.width)!important;} --> 介绍 本篇文章主要是列举在shell命令中常出现的一些用来做比较的运算符,这些运算符是 ...
 - [51单片机] 以从0开始做4位8段共阴数码管3461AS驱动谈细节决定高质量DIY
			
目录 1)问题产生 2)失败尝试 3)最终方案 4)使用方法 5)知识共享 1)问题产生 在上一篇“以PWM控制直流电机为例建一个简单的51工程框架”中已向大家介绍了一个封装好的8位8段数码管的驱动( ...