POJ 1386 Play on Words(欧拉路)
http://poj.org/problem?id=1386
题意:
给出多个单词,只有单词首字母与上一个单子的末尾字母相同时可以连接,判断所有字母是否可以全部连接在一起。
思路:
判断是否存在欧拉道路,每个单词只需要处理首字母和尾字母就可以了。
还有需要注意的就是需要判断图是否连通,我在这里用了并查集来判断。
有向图D存在欧拉道路的充要条件是:D为有向图,D的基图连通,并且所有顶点的出度与入度都相等;或者除两个顶点外,其余顶点的出度与入度都相等,而这两个顶点中一个顶点的出度与入度之差为1,另一个顶点的出度与入度之差为-1。
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<sstream>
#include<vector>
#include<stack>
#include<queue>
#include<cmath>
#include<map>
#include<set>
using namespace std;
typedef long long ll;
typedef pair<int,int> pll;
const int INF = 0x3f3f3f3f;
const int maxn = + ; int n;
int in[],out[];
int g[][];
int p[];
char str[maxn]; int Find(int x)
{
return x==p[x]?x:p[x]=Find(p[x]);
} int main()
{
//freopen("in.txt","r",stdin);
int T;
scanf("%d",&T);
while(T--)
{
memset(g,,sizeof(g));
memset(in,,sizeof(in));
memset(out,,sizeof(out)); for(int i=;i<;i++) p[i]=i;
scanf("%d",&n);
getchar();
for(int i=;i<n;i++)
{
scanf("%s",str);
int len=strlen(str);
int u=str[]-'a';
int v=str[len-]-'a';
g[u][v]=;
out[u]++;
in[v]++; int x=Find(u);
int y=Find(v);
if(x!=y) p[x]=y;
} int cnt=;
for(int i=;i<;i++)
{
if((in[i]||out[i]) && p[i]==i)
cnt++;
}
if(cnt>)
{
puts("The door cannot be opened.");
}
else
{
int num1=,num2=, num3=;
for(int i=;i<;i++)
{
if(in[i]!=out[i])
{
if(in[i]-out[i]==) num1++;
else if(in[i]-out[i]==-) num2++;
else num3++;
}
}
if(num3== && ((num1== && num2==)||(num1== && num2==)))
puts("Ordering is possible.");
else puts("The door cannot be opened.");
}
}
return ;
}
POJ 1386 Play on Words(欧拉路)的更多相关文章
- Colored Sticks POJ - 2513(trie树欧拉路)
		
题意: 就是无向图欧拉路 解析: 不能用map..超时 在判断是否只有一个联通的时候,我比较喜欢用set,但也不能用set,会超时,反正不能用stl emm 用trie树来编号就好了 #include ...
 - poj 1386 Play on Words(有向图欧拉路+并查集)
		
题目链接:http://poj.org/problem?id=1386 思路分析:该问题要求判断单词是否能连接成一条直线,转换为图论问题:将单词的首字母和尾字母看做一个点,每个单词描述了一条从首字母指 ...
 - POJ 1637 Sightseeing tour (混合图欧拉路判定)
		
Sightseeing tour Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 6986 Accepted: 2901 ...
 - poj 1780 code(欧拉路)
		
/* 对于n为密码想要序列最短 那么 1234 2345 这两个一定挨着 就是说 前一个的后n-1位是后一个的前n-1位 假设n==3 我们用0-99作为点的编号建图 然后每个点连出去10条边 两个相 ...
 - POJ 2513 - Colored Sticks - [欧拉路][图的连通性][字典树]
		
题目链接: http://poj.org/problem?id=2513 http://bailian.openjudge.cn/practice/2513?lang=en_US Time Limit ...
 - POJ 2230 (欧拉路)
		
分析: 基础的欧拉路算法,变化在于要求每条边正向和反向各走一遍. 链式前向星构图,只要标记走过的单向边,边找边输出即可. code #include <iostream> #include ...
 - poj 1637 Sightseeing tour【最大流+欧拉路】
		
参考:https://www.cnblogs.com/kuangbin/p/3537525.html 这篇讲的挺好的 首先分清欧拉路和欧拉环: 欧拉路:图中经过每条边一次且仅一次的路径,要求只有两个点 ...
 - POJ 2513 trie树+并查集判断无向图的欧拉路
		
生无可恋 查RE查了一个多小时.. 原因是我N define的是250500 应该是500500!!!!!!!!! 身败名裂,已无颜面对众人.. 吐槽完了 我们来说思路... 思路: 判有向图能否形成 ...
 - poj 2513 Colored Sticks (trie树+并查集+欧拉路)
		
Colored Sticks Time Limit: 5000MS Memory Limit: 128000K Total Submissions: 40043 Accepted: 10406 ...
 - 欧拉路&&欧拉回路  概念及其练习
		
欧拉路: 如果给定无孤立结点图G,若存在一条路,经过图中每边一次且仅一次,这条路称为欧拉路: 如果给定无孤立结点图G,若存在一条回路,经过图中每边一次且仅一次,那么该回路称为欧拉回路. 存在欧拉回路的 ...
 
随机推荐
- 【BZOJ4429】[Nwerc2015] Elementary Math小学数学 最大流
			
[BZOJ4429][Nwerc2015] Elementary Math小学数学 Description Ellen给她的学生教小学数学.期末考试已经来临了.考试有n个题目,每一个题目学生们都要对一 ...
 - OneThink友情链接插件使用!
			
OneThink友情链接插件使用: 直接安装插件就好,查看数据库会有:onethink_links 这个表: 写 links 标签,调用友情链接: <?php namespace Common\ ...
 - 170612、web如何项目优化
			
Web性能优化分为服务器端和浏览器端两个方面. 一.浏览器端,关于浏览器端优化,分很多个方面1.压缩源码和图片JavaScript文件源代码可以采用混淆压缩的方式,CSS文件源代码进行普通压缩,JPG ...
 - js 的正则表达式 部分展示test()方法的验证功能
			
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
 - 每次收到的 HTTP 请求,就可以打开一个 SqlSession,返回一个响应,就关闭它
			
mybatis – MyBatis 3 | 入门 http://www.mybatis.org/mybatis-3/zh/getting-started.html 作用域(Scope)和生命周期 理解 ...
 - Nginx正向代理配置
			
服务器端: server { resolver 8.8.8.8; resolver_timeout 5s; listen 0.0.0.0:8888; access_log /usr/local/ngi ...
 - python使用tesseract-ocr完成验证码识别
			
全自动区分计算机和人类的公开图灵测试(Completely Automated Public Turing test to tell Computers and Humans Apart) 简称CAP ...
 - SQL Server简洁查询正在运行SQL(等待事件)
			
通常我们可以使用 sp_who2 我们希望更加简洁的信息,下面这个查询使用系统表sys.sysprocesses,以及sys.dm_exec_sql_text做OUTER APPLY. T-SQL是这 ...
 - go-003-基础语法
			
1.行分隔符 一行代表一个语句结束. 如果一行多个,使用“;”分割,不推荐使用,建议使用默认一行一个语句 2.标识符 标识符用来命名变量.类型等程序实体.一个标识符实际上就是一个或是多个字母(A~Z和 ...
 - SWIG和PInvoke学习(1)
			
1. 简介 SWIG是个帮助使用C或者C++编写的软件能与其它各种高级编程语言进行嵌入联接的开发工具. SWIG能应用于各种不同类型的语言包括常用脚本编译语言例如Perl, PHP, Python, ...