Time Limit: 1 second

Memory Limit: 128 MB

【问题描述】

给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒)。请构造一个有n+1个字母的字符串使得每个字母对都在这个字符串中出现。

【输入格式】

第一行输入一个正整数n。 以下n行每行两个字母,表示这两个字母需要相邻。

【输出格式】

输出满足要求的字符串。 如果没有满足要求的字符串,请输出“No Solution”。 如果有多种方案,请输出前面的字母的ASCII编码尽可能小的(字典序最小)的方案

【数据规模】

Sample Input1

4
aZ
tZ
Xt
aX

Sample Output1

XaZtX

【样例说明】

不同的无序字母对个数有限,n的规模可以通过计算得到。
【题解】
把两个字母看做边的两端点。则所输入的n个字母对就是n条边。所求的字符串就是这n条边构成的图的欧拉路径。这里说的n+1个字符。如果它不是一条链。则一定是存在一个环的。

然后用存在欧拉路的定理先判定会不会有欧拉路;
即统计所有点的出度的奇偶个数。
如果奇数的出度数总数为0(全是偶数)或2.则存在欧拉路。
如果全是偶数。就从字典序最小的一个点开始dfs找就可以。
如果有两个奇数的点。就从字典序较小的那个奇数点开始dfs。
是一定能找到的。链的情况也可以包括。

其他情况都可以用欧拉图定理排除掉。
【代码】
#include <cstdio>
#include <stdlib.h> int a[256][256] = { 0 }, n, w[256][256] = { 0 },chudu[256];
char temp[256]; void dfs(int x, int now)//现在到达x顶点。下一个点是第now个点
{
if (now == n + 2)//如果已经找到第n+1个点了。
{
for (int i = 1; i <= n + 1; i++)//则输出之前记录的路径
putchar(temp[i]);
exit(0);//直接结束所有的程序。
}
for (int i = 1;i<= 255;i++)//寻找x的出度。并记录这个出度
if (w[x][i] == 1)
{
w[x][i] = 0;
w[i][x] = 0;//反向边也要置0.不然又会往回走。
temp[now] = i;//记录路径
dfs(i, now + 1);//继续搜索。
w[x][i] = 1;
w[i][x] = 1;
}
} int main()
{
scanf("%d", &n);//输入n条边
for (int i = 1; i <= n; i++)
{
char s[10];
scanf("%s", s);//以字符串的形式输入。
int x = s[0], y = s[1];//获取两个端点
if (w[x][y] == 0)//如果没有重边
{
w[x][y] = 1;//记录边
w[y][x] = 1;
a[x][0]++;//记录其第a[x][0]个出度是什么
a[x][a[x][0]] = y;
a[y][a[y][0]] = x;
chudu[x]++;//相应的出度递增。
chudu[y]++;
}
}
int jishu = 0,start = 0;//统计奇数出度的个数。以及从哪里开始进行dfs.
for (int i = 1; i <= 255; i++)
{
if (chudu[i] > 0 && start == 0)//找到一个字典序最小的有出度的点。开始
start = i;
if ((chudu[i] % 2) == 1)//如果有奇数点。就从奇数点里面字典序最小的开始。
{
if (jishu == 0)
start = i;
jishu++;
}
}
if (jishu != 0 && jishu != 2)//如果不全为偶数且奇数点的个数不为2.则输出无解信息。
{
printf("No Solution");
return 0;
}
temp[1] = start;//否则从开始点开始搜寻欧拉路径 记录路径。
dfs(start,2);
return 0;
}

【u016】无序字母对的更多相关文章

  1. 洛谷P1341 无序字母对[无向图欧拉路]

    题目描述 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造一个有n+1个字母的字符串使得每个字母对都在这个字符串中出现. 输入输出格式 输入格式: 第一行输入一 ...

  2. 洛谷 P1341 无序字母对 Label:欧拉路 一笔画

    题目描述 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造一个有n+1个字母的字符串使得每个字母对都在这个字符串中出现. 输入输出格式 输入格式: 第一行输入一 ...

  3. P1341 无序字母对 欧拉回路

    题目描述 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造一个有n+1个字母的字符串使得每个字母对都在这个字符串中出现. 输入输出格式 输入格式: 第一行输入一 ...

  4. [luogu1341]无序字母对【欧拉回路】

    题目描述 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造一个有n+1个字母的字符串使得每个字母对都在这个字符串中出现. 分析 欧拉回路的模板题. 暴力删边欧拉 ...

  5. P1341 无序字母对

    题目描述 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造一个有n+1个字母的字符串使得每个字母对都在这个字符串中出现. 输入输出格式 输入格式: 第一行输入一 ...

  6. 【洛谷P1341】无序字母对

    题目大意:给定 n 个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造一个有 n+1 个字母的字符串使得每个字母对都在这个字符串中出现. 题解:每个无需字母对可以看成无 ...

  7. 洛谷 P1341 无序字母对 解题报告

    P1341 无序字母对 题目描述 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造一个有n+1个字母的字符串使得每个字母对都在这个字符串中出现. 输入输出格式 ...

  8. 无序字母对 character

    无序字母对 character 题目描述 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造一个有n+1个字母的字符串使得每个字母对都在这个字符串中出现. 输入 ...

  9. 「LuoguP1341」 无序字母对(欧拉回路

    题目描述 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造一个有n+1个字母的字符串使得每个字母对都在这个字符串中出现. 输入输出格式 输入格式: 第一行输入一 ...

随机推荐

  1. ZOJ QS Network

    QS Network Time Limit: 2 Seconds      Memory Limit: 65536 KB Sunny Cup 2003 - Preliminary Round Apri ...

  2. cf1051F. The Shortest Statement(最短路/dfs树)

    You are given a weighed undirected connected graph, consisting of nn vertices and mm edges. You shou ...

  3. Spark MLlib LDA 源代码解析

    1.Spark MLlib LDA源代码解析 http://blog.csdn.net/sunbow0 Spark MLlib LDA 应该算是比較难理解的,当中涉及到大量的概率与统计的相关知识,并且 ...

  4. Http请求连接池 - HttpClient 的 PoolingHttpClientConnectionManager

    两个主机建立连接的过程是非常复杂的一个过程,涉及到多个数据包的交换,而且也非常耗时间.Http连接须要的三次握手开销非常大,这一开销对于比較小的http消息来说更大.但是假设我们直接使用已经建立好的h ...

  5. kibana中信息分类查询显示的方法

    1.什么是kibana? kibana是ELK(elasticsearch+logstash+kibana)中的K,它是一个可灵活的分析和可视化平台,主要是显示数据以及根据这些数据绘出一些可视化图表, ...

  6. app 自动化测试 Appium+Java可以运行的代码

    地址:http://www.cnblogs.com/sunny-sl/p/6520465.html

  7. Redis的高级应用-事务处理、持久化、发布与订阅消息、虚拟内存使用

    三.事务处理 Redis的事务处理比较简单.只能保证client发起的事务中的命令可以连续的执行,而且不会插入其他的client命令,当一个client在连接 中发出multi命令时,这个连接就进入一 ...

  8. 【CS Round #43 C】Rectangle Partition

    [链接]点击打开链接 [题意] 有一辆火车,它的长度为L,然后假设这辆车现在随机可能地出现在0..D之间,然后假设它已经耗光了油. 问你它需要走的期望距离是多少. 这里要走的距离指的是车里最近的加油站 ...

  9. amazeui学习笔记--css(HTML元素3)--表单Form

    amazeui学习笔记--css(HTML元素3)--表单Form 一.总结 1.form样式使用:在容器上添加 .am-form class,容器里的子元素才会应用 Amaze UI 定义的样式. ...

  10. μC/OS中的任务就绪表

    为了便于对就绪表的查找,μC/OSII又定义了一个数据类型为INT8U的变量OSRdyGrp, 并使该变量的每一位都对应OSRdyTbl[ ]的一个任务组(即数组的一个元素),如果某任务组中 有任务就 ...