题意:要开启一扇门,n个单词是密码,n个单词中,如果一个单词的首字母和前一个单词的尾字母相同,并且每个单词都能这么连起来且只用一次,则门可以开启,否则不能开启,现给出单词,判断门是否可以开。

有向图欧拉通路充要条件:D为有向图,D的基图连通,并且所有顶点的出度与入度都相等;或者除两个顶点外,其余顶点的出度与入度都相等,而这两个顶点中一个顶点的出度与入度之差为1,另一个顶点的出度与入度之差为-1。

有向图欧拉回路充要条件:当D的所有顶点的出、入度都相等时,D中存在有向欧拉回路。

思路:一个单词关键是首字母和尾字母,可以把首字母和尾字母看成顶点,这个单词看成这两个顶点间的边,这么建图,于是原题就变成了找这个图中是否存在欧拉通路或者欧拉回路。建完图之后只需要根据定理判断每个顶点的出度、入度以及图的连通性即可。

转自:http://blog.csdn.net/zzzz40/article/details/38659755?utm_source=tuicool&utm_medium=referral

判断有多少个连通分量可以用并查集或者DFS。。我就都写了一遍

(其实是在给某人找错,就顺便写了一遍)

这是用并查集写的,写得不太好看。。(凑活看吧)

#include <cstdio>
#include <cstring>
using namespace std;
char a[1050],vis[26],VIS[26],f[26];
int cases,n,out[26],in[26],tot=0,temp,ans,ansx,ansy,len;
int find(int x){return x==f[x]?x:f[x]=find(f[x]);}
int main(){
scanf("%d",&cases);
while(cases--){
temp=ans=ansx=ansy=0;
for(int i=0;i<26;i++)f[i]=i;
memset(vis,0,sizeof(vis));
memset(VIS,0,sizeof(VIS));
memset(in,0,sizeof(in));
memset(out,0,sizeof(out));
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%s",a);
len=strlen(a)-1;
a[0]-='a',a[len]-='a';
out[a[0]]++,in[a[len]]++;
if(!vis[a[len]])vis[a[len]]++;
f[find(a[len])]=find(a[0]);
}
for(int i=0;i<=25;i++)
if(vis[i]&&!VIS[find(i)])
VIS[find(i)]++,ans++;
if(ans>1){puts("The door cannot be opened.");continue;}
for(int i=0;i<=25;i++){
if(in[i]-out[i]==1)ansx++;
else if(out[i]-in[i]==1)ansy++;
else if(in[i]!=out[i])temp++;
}
if(ansx==ansy&&(ansx==1||ansx==0)&&!temp)puts("Ordering is possible.");
else puts("The door cannot be opened.");
}
}

DFS:

#include <cstdio>
#include <Cstring>
#include <algorithm>
using namespace std;
char a[1005];
bool vis[26],VIS[26],flag;
int cases,tot,v[200010],next[200010],first[2010],n,in[26],out[26];
int cnt1,cnt2,cnt3;
void add(int x,int y){v[tot]=y;next[tot]=first[x];first[x]=tot++;}
void dfs(int x){
for(int i=first[x];~i;i=next[i])
if(!VIS[v[i]])VIS[v[i]]=1,dfs(v[i]);
}
int main(){
scanf("%d",&cases);
while(cases--){
flag=1;tot=cnt1=cnt2=cnt3=0;
memset(first,-1,sizeof(first));
memset(vis,0,sizeof(vis));
memset(VIS,0,sizeof(VIS));
memset(in,0,sizeof(in));
memset(out,0,sizeof(out));
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%s",a);
int len=strlen(a)-1;
a[0]-='a';a[len]-='a';
add(a[0],a[len]);
in[a[len]]++;out[a[0]]++;
vis[a[0]]=vis[a[len]]=1;
}
for(int i=0;i<26;i++){
if(in[i]!=out[i])cnt3++;
if(in[i]==out[i]-1)cnt1++;
if(out[i]==in[i]-1)cnt2++;
}
if(cnt3==2&&cnt1==1&&cnt2==1)
for(int i=0;i<26;i++){
if(in[i]<out[i]){
VIS[i]=1,dfs(i);
for(int i=0;i<26;i++)
if(vis[i]!=VIS[i])flag=0;
break;
}
}
else if(!cnt3){
dfs(a[0]);VIS[a[0]]=1;
for(int i=0;i<26;i++)
if(vis[i]!=VIS[i])flag=0;
}
else {puts("The door cannot be opened.");continue;}
if(flag)puts("Ordering is possible.");
else puts("The door cannot be opened.");
}
}

POJ 1386 判断欧拉回路的更多相关文章

  1. POJ 1386 Play on Words(欧拉图的判断)

    Play on Words Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 11838   Accepted: 4048 De ...

  2. poj 1386 Play on Words 有向欧拉回路

    题目链接:http://poj.org/problem?id=1386 Some of the secret doors contain a very interesting word puzzle. ...

  3. poj 1386 Play on Words门上的单词【欧拉回路&&并查集】

    题目链接:http://poj.org/problem?id=1386 题目大意:给你若干个字符串,一个单词的尾部和一个单词的头部相同那么这两个单词就可以相连,判断给出的n个单词是否能够一个接着一个全 ...

  4. POJ 1386 Play on Words(单词建图+欧拉通(回)路路判断)

    题目链接:http://poj.org/problem?id=1386 题目大意:给你若干个字符串,一个单词的尾部和一个单词的头部相同那么这两个单词就可以相连,判断给出的n个单词是否能够一个接着一个全 ...

  5. poj 1386 Play on Words(有向图欧拉回路)

    /* 题意:单词拼接,前一个单词的末尾字母和后一个单词的开头字母相同 思路:将一个单词的开头和末尾单词分别做两个点并建一条有向边!然后判断是否存在欧拉回路或者欧拉路 再次强调有向图欧拉路或欧拉回路的判 ...

  6. HDU 1116 || POJ 1386 || ZOJ 2016 Play on Words (欧拉回路+并查集)

    题目链接 题意 : 有很多门,每个门上有很多磁盘,每个盘上一个单词,必须重新排列磁盘使得每个单词的第一个字母与前一个单词的最后一个字母相同.给你一组单词问能不能排成上述形式. 思路 :把每个单词看成有 ...

  7. [欧拉回路] poj 1386 Play on Words

    题目链接: http://poj.org/problem?id=1386 Play on Words Time Limit: 1000MS   Memory Limit: 10000K Total S ...

  8. poj 1386 Play on Words(有向图欧拉路+并查集)

    题目链接:http://poj.org/problem?id=1386 思路分析:该问题要求判断单词是否能连接成一条直线,转换为图论问题:将单词的首字母和尾字母看做一个点,每个单词描述了一条从首字母指 ...

  9. POJ 1386 Play on Words(欧拉路)

    http://poj.org/problem?id=1386 题意: 给出多个单词,只有单词首字母与上一个单子的末尾字母相同时可以连接,判断所有字母是否可以全部连接在一起. 思路: 判断是否存在欧拉道 ...

随机推荐

  1. 两款工作流JBPM和CCBPM的对比

    以国外流行的工作流jbpm4的模式与当今中国开源的ccbpm(ccflow和jflow的总称)流程引擎对照.以便让各位能够了解到中国国情的工作流引擎与国际流行的设计规则的差别.不同.与优缺点. 国外工 ...

  2. VTK嵌入MFC同步显示

    使用VTK嵌入MFC,实现四视图更新,机制和细节参考原文. 原文链接:http://blog.csdn.net/www_doling_net/article/details/8939115 原文代码: ...

  3. day37-1 面向对象高阶

    目录 面向对象高阶 isinstance issubclass 反射(自省) 模块的使用 放在类的使用 call 面向对象高阶 isinstance 判断是否为实例化对象,以后可以用来取代type 和 ...

  4. eas启动服务器时非法组件

    EAS实例启动报系统中存在非法组件,实例启动失败:   组件检查机制,要求除了 $EAS_HOME eas\server\lib: $EAS_HOME \eas\server\deploy\files ...

  5. 51nod1085 背包问题【动态规划】

    在N件物品取出若干件放在容量为W的背包里,每件物品的体积为W1,W2--Wn(Wi为整数),与之相对应的价值为P1,P2--Pn(Pi为整数).求背包能够容纳的最大价值. Input 第1行,2个整数 ...

  6. [luogu1155 NOIP2008] 双栈排序 (二分图染色)

    传送门 Description Input 第一行是一个整数 n . 第二行有 n 个用空格隔开的正整数,构成一个 1−n 的排列. Output 共一行,如果输入的排列不是"可双栈排序排列 ...

  7. Solr学习记录:Getting started

    目录 Solr学习记录:Getting started 1.Solr Tutorial 2. A Quick Overview Solr学习记录:Getting started 本教程使用环境:jav ...

  8. EurekaLog是什么鬼?

    D的all工程文件打开后,莫名其妙就处于等待打开状态.因为最后一次调整是安装了RO9.0.所以一直怀疑是RO的原因.再加上win7授权问题,安装RO一直不顺当.所以折腾的时间最多. 其他把RO全部卸载 ...

  9. AM335X开发板+4G模块 调试小结

    1.找到开发版配套资料中的linux内核源码包linux-3.2.0-Litev2.3-nand-2017-3-24.tar.gz 2.解压内核源码包,打开内核源码文件 option.c(路径为 dr ...

  10. DNS绑定多个IP地址

    DNS轮循技术 首先介绍一个DNS系统:传统的DNS解析都是一个域名对应一个IP地址,但是通过DNS轮循技术(负载平衡技术)可以做到一个域名对应到多个IP 上. 这样大家难免就会问,这个技术有什么用呢 ...