[题解]UVA10129 Play on Words
链接:http://vjudge.net/problem/viewProblem.action?id=19492
描述:单词接龙
思路:求欧拉回路或欧拉道路。
首先建图,以字母为节点,单词为边。因为单词不可能倒序,所以是有向图。
判断图的连通性,dfs就可以做到,把它当成无向图就好了。然后判断点的出入度就可以判断是不是欧拉回路或者欧拉道路。
下面是我的实现。
1 #include <iostream>
2 #include <cstdio>
3 #include <cstring>
4 using namespace std;
5 #define Max 30
6 #define MaxLen 1010
7 int T,n,Bgn;
8 int Edge[Max][Max],Chu[Max],Ru[Max];
9 bool vis[Max];
10 char str[MaxLen];
11 inline void Get_int(int &Ret)
12 {
13 char ch;
14 bool flag=false;
15 for(;ch=getchar(),ch<'0'||ch>'9';)
16 if(ch=='-')
17 flag=true;
18 for(Ret=ch-'0';ch=getchar(),ch>='0'&&ch<='9';Ret=Ret*10+ch-'0');
19 flag&&(Ret=-Ret);
20 }
21 inline void Read()
22 {
23 Get_int(n);
24 memset(vis,false,sizeof(vis));
25 memset(Chu,0,sizeof(Chu));
26 memset(Ru,0,sizeof(Ru));
27 memset(Edge,0,sizeof(Edge));
28 int i,u,v,Len;
29 for(i=1;i<=n;i++)
30 {
31 do
32 {
33 scanf("%s",str);
34 Len=strlen(str);
35 }while(!Len);
36 u=str[0]-'a'+1; v=str[Len-1]-'a'+1;
37 //if(u==v) continue;
38 Edge[u][v]++;Edge[v][u]++;
39 Chu[u]++;Ru[v]++;
40 vis[u]=vis[v]=true;
41 }
42 Bgn=u;
43 }
44 void Dfs(int u)
45 {
46 vis[u]=false;
47 for(int i=1;i<=26;i++)
48 if(Edge[u][i]&&vis[i])
49 Dfs(i);
50 }
51 inline bool Solve()
52 {
53 int i,ch=0,ru=0;
54 Dfs(Bgn);
55 for(i=1;i<=26;i++)
56 {
57 if(vis[i])
58 return false;
59 if(Chu[i]!=Ru[i])
60 {
61 if(Chu[i]-Ru[i]==1)
62 ch++;
63 else if(Ru[i]-Chu[i]==1)
64 ru++;
65 else
66 return false;
67 }
68 }
69 if((ch==1&&ru==1)||(ch==0&&ru==0))
70 return true;
71 return false;
72 }
73 int main()
74 {
75 Get_int(T);
76 while(T--)
77 {
78 Read();
79 if(Solve())
80 printf("Ordering is possible.\n");
81 else
82 printf("The door cannot be opened.\n");
83 }
84 return 0;
85 }
[题解]UVA10129 Play on Words的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
随机推荐
- React教程
教程 一.demo <!DOCTYPE html> <html> <head> <meta charset="UTF-8"/> &l ...
- 利用SelectPdf插件将网页生成PDF
简介 适用于.NET Framework和.NET Core的HTML至PDF转换器 SelectPdf提供的在线html到pdf转换器使用.NET的Select.Pdf库中的html到pdf转换器. ...
- 重启WAS实例
/opt/IBM/WebSphere90/AppServer/profiles/appprofile/bin/startServer.sh DASMGW01IDHK-AS01 /opt/IBM/Web ...
- rsync.sh
#!/bin/bash file1=`du -sm /var/www/vhosts/|awk '{print $1}'` ps=`ps -C rsync --no-header|wc -l` if [ ...
- 使用Hot Chocolate和.NET 6构建GraphQL应用(4) —— 实现Query映射功能
系列导航 使用Hot Chocolate和.NET 6构建GraphQL应用文章索引 需求 在上一篇文章使用Hot Chocolate和.NET 6构建GraphQL应用(3) -- 实现Query基 ...
- Python写春联(turtle版)
Python就好比编程界的瑞士军刀,开箱即用.无所不能.这得益于Python简洁易用的语法,以及丰富的第三方库,你想在电脑上做什么,总能找到事半功倍的第三方库.比如,在这新春佳节之际,用Python来 ...
- JVM专题1: 类和类加载机制
合集目录 JVM专题1: 类和类加载机制 Java对象的结构 在HotSpot虚拟机中, 对象在内存中存储的布局可以分为3块区域 对象头Header 实例数据Instance Data 对齐填充Pad ...
- 一 简单介绍aws。
aws入门 一 什么是aws? /* 概念: AWS就是 Amazon Web Servies, 亚马逊云计算服务平台. 是一款云服务. */ 二 aws可以做什么? // 可以在aws,创建我们需要 ...
- 写程序时try,catch查看报错的行号
try { //////////////// 代码段 //////////////// }catch(Exception ex) { MessageBox.Show(ex.St ...
- 男孩和女孩(二)-->相识
转载请注明来源:https://www.cnblogs.com/hookjc/ 那天是男孩的十九岁生日:男孩还是像平常一样,一大早就起来了(快七点了).一切都是那么的平常,直到第一节课下课,男孩的同窗 ...