题意:

输入n(n≤100000)个单词,是否可以把所有这些单词排成一个序列,使得每个单词的第一个字母和上一个单词的最后一个字母相同(例如acm、malform、mouse)。每个单词最

多包含1000个小写字母。输入中可以有重复单词。

分析:

可以看出, 把字母看成顶点(最多26个), 然后单词就是有向边, 单词与单词之间的关系就连接起来了, 然后建立邻接矩阵, 自环的可以忽略, 记录输入的字母有哪几个, 字母的度数。

然后图中存在欧拉通路的条件有2个

(1) 连通(我用了dfs来判断)

(2) 要么没有奇度顶点, 如果有, 那么肯定是有一个入度-出度=1 有一个入度-出度= -1。

用好这两个条件就可以判定应该就可以得出答案了

 #include <bits/stdc++.h>
using namespace std;
int degree[],used[];//度数 有没有使用过
int G[][];// 邻接矩阵
int n;
int id(int a){
return a-'a';
}
int vis[];
void dfs(int u){
vis[u] = ;
for(int i = ; i < ; i++){
if(G[u][i] && !vis[i]){
dfs(i);
}
}
} bool judge(){
int num1 = , num2 = ;
int u = , v;
for(int i = ; i< ; i++){
if(used[i]){
u = i;//u一开始等于图中任意一个顶点
break;
}
}
for(int i = ; i < ; i++){
if(used[i]){
if(degree[i] != ){
if(degree[i] == ) {num1++; u = i;}//此时u就要等于入度>出度的顶点了
else if(degree[i] == -){num2++; v = i;}
else return false;
}
}
}
if((num1 || num2) && num1 + num2 != ) return false;//如果有 而且不是只有2个 就可以判为false了 memset(vis,,sizeof(vis));
dfs(u);
for(int i = ; i < ; i++){
if(used[i] && !vis[i]){//如果有这个点, 遍历又没遍历到 false;
return false;
}
}
return true; }
int main(){
int T;
scanf("%d", &T);
while(T--){
memset(degree,,sizeof(degree));
memset(used,,sizeof(used));
memset(G,,sizeof(G));
scanf("%d", &n);
for(int i = ; i < n; i++){
char s[];
scanf("%s", s);
int s1 = s[] , s2 = s[strlen(s)-];
if(s1 != s2){
G[id(s1)][id(s2)] = ;
}
used[s1 -'a'] = ;
used[s2 -'a'] = ;
degree[id(s1)]++;//出度++
degree[id(s2)]--;//入度--
}
// for(int i = 0; i<26; i++){//观察度数
// if(used[i])
// printf("%c %d\n", i+'a', degree[i]);
// }
printf("%s\n", judge()? "Ordering is possible.":"The door cannot be opened.");
}
}

UVa 10129 单词 (欧拉通路)的更多相关文章

  1. poj2513- Colored Sticks 字典树+欧拉通路判断

    题目链接:http://poj.org/problem?id=2513 思路很容易想到就是判断欧拉通路 预处理时用字典树将每个单词和数字对应即可 刚开始在并查集处理的时候出错了 代码: #includ ...

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

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

  3. POJ 1386 Play on Words(有向欧拉通路 连通图)

    题意  见下方中文翻译 每一个单词能够看成首尾两个字母相连的一条边  然后就是输入m条边  推断是否能构成有向欧拉通路了 有向图存在欧拉通路的充要条件: 1. 有向图的基图连通: 2. 全部点的出度和 ...

  4. ACM/ICPC 之 DFS求解欧拉通路路径(POJ2337)

    判断是欧拉通路后,DFS简单剪枝求解字典序最小的欧拉通路路径 //Time:16Ms Memory:228K #include<iostream> #include<cstring& ...

  5. POJ 1300 欧拉通路&欧拉回路

    系统的学习一遍图论!从这篇博客开始! 先介绍一些概念. 无向图: G为连通的无向图,称经过G的每条边一次并且仅一次的路径为欧拉通路. 如果欧拉通路是回路(起点和终点相同),则称此回路为欧拉回路. 具有 ...

  6. poj 2513 连接火柴 字典树+欧拉通路 好题

    Colored Sticks Time Limit: 5000MS   Memory Limit: 128000K Total Submissions: 27134   Accepted: 7186 ...

  7. hdu1116有向图判断欧拉通路判断

    Play on Words Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) T ...

  8. 欧拉回路&欧拉通路判断

    欧拉回路:图G,若存在一条路,经过G中每条边有且仅有一次,称这条路为欧拉路,如果存在一条回路经过G每条边有且仅有一次, 称这条回路为欧拉回路.具有欧拉回路的图成为欧拉图. 判断欧拉通路是否存在的方法 ...

  9. POJ2513Colored Sticks(欧拉通路)(字典树)(并查集)

                                                             Colored Sticks Time Limit: 5000MS   Memory ...

随机推荐

  1. Linux之旅第一篇-目录结构及操作目录

    一.引言 Linux对java开发来说也是一项必备的技能,因为项目基本都是部署在Linux操作系统的服务器中,虽然项目不一定需要我们去部署,但不管是自己测试环境部署,还是一些生产环境中日志的查看,Li ...

  2. 安装 Spring 框架库

    下载地址:http://repo.spring.io/release/org/springframework/spring

  3. 暴力 ZOJ 1403 Safecracker

    题目传送门 /* 暴力:纯暴力,在家水水 */ #include <cstdio> #include <cstring> #include <algorithm> ...

  4. vue.js学习参考手册

    参考手册 示例:www.51siyuan.cn/161.html

  5. 依赖注入(IOC) 详解

    https://blog.csdn.net/qq_27093465/article/details/52547290 https://blog.csdn.net/qq_27093465/article ...

  6. 电商网站项目Angular+Bootstrap+Node+Express+Mysql

    1.登陆 2.注册 3.主页 4.购物车 5.管理中心 6.文件上传 代码: https://github.com/Carol0311/min_Shop.git 后期会持续进行功能更新以及开发阶段遇到 ...

  7. iOS游戏开发之UIDynamic

    iOS游戏开发之UIDynamic 简介 什么是UIDynamic UIDynamic是从iOS 7开始引入的一种新技术,隶属于UIKit框架 可以认为是一种物理引擎,能模拟和仿真现实生活中的物理现象 ...

  8. 当前主要的常用的PHP环境部署套件比较

    当前主要的常用的PHP环境部署套件比较 作为新手,需要学习PHP,或者需要搭建PHP+MySQL运行环境时,就需要去找各种搭建方法,一步一步按照操作流程操作,不仅繁琐,而且容易出错,还会带来安全隐患. ...

  9. 设计模式之一:strategy pattern

    定义算法族,彼此之间可以替换.变化的方法抽出封装,不变的父类定义继承.多用组合少用继承. 代码示例先不贴了.

  10. VS2015 update3 安装 asp.net core 失败

    CMD 命令下执行: C:\DotNetCore\DotNetCore.1.0.0-VS2015Tools.Preview2.exe SKIP_VSU_CHECK=1