题目描述

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

输入输出格式

输入格式:

第一行输入一个正整数n。

以下n行每行两个字母,表示这两个字母需要相邻。

输出格式:

输出满足要求的字符串。

如果没有满足要求的字符串,请输出“No Solution”。

如果有多种方案,请输出前面的字母的ASCII编码尽可能小的(字典序最小)的方案

输入输出样例

输入样例#1: 复制

  1. 4
  2. aZ
  3. tZ
  4. Xt
  5. aX
输出样例#1: 复制

  1. XaZtX

说明

【数据规模与约定】

不同的无序字母对个数有限,n的规模可以通过计算得到。

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. typedef long long ll;
  4. #define inf 2147483647
  5. const ll INF = 0x3f3f3f3f3f3f3f3fll;
  6. #define ri register int
  7. template <class T> inline T min(T a, T b, T c)
  8. {
  9. return min(min(a, b), c);
  10. }
  11. template <class T> inline T max(T a, T b, T c)
  12. {
  13. return max(max(a, b), c);
  14. }
  15. template <class T> inline T min(T a, T b, T c, T d)
  16. {
  17. return min(min(a, b), min(c, d));
  18. }
  19. template <class T> inline T max(T a, T b, T c, T d)
  20. {
  21. return max(max(a, b), max(c, d));
  22. }
  23. #define scanf1(x) scanf("%d", &x)
  24. #define scanf2(x, y) scanf("%d%d", &x, &y)
  25. #define scanf3(x, y, z) scanf("%d%d%d", &x, &y, &z)
  26. #define scanf4(x, y, z, X) scanf("%d%d%d%d", &x, &y, &z, &X)
  27. #define pi acos(-1)
  28. #define me(x, y) memset(x, y, sizeof(x));
  29. #define For(i, a, b) for (int i = a; i <= b; i++)
  30. #define FFor(i, a, b) for (int i = a; i >= b; i--)
  31. #define bug printf("***********\n");
  32. #define pb push_back
  33. const int N = ;
  34. const int mod=;
  35. // name*******************************
  36. int du[N];
  37. int G[N][N];
  38. stack<int>S;
  39. int n;
  40. int s;
  41. char str[];
  42. // function******************************
  43. void dfs(int x)
  44. {
  45. For(i,,)
  46. {
  47. if(G[x][i])
  48. {
  49. G[x][i]--;
  50. G[i][x]--;
  51. dfs(i);
  52. }
  53. }
  54. S.push(x);
  55. }
  56.  
  57. //***************************************
  58. int main()
  59. {
  60. // ios::sync_with_stdio(0);
  61. // cin.tie(0);
  62. // freopen("test.txt", "r", stdin);
  63. // freopen("outout.txt","w",stdout);
  64. cin>>n;
  65. For(i,,n)
  66. {
  67. int a,b;
  68. scanf("%s",str);
  69. if(str[]<='Z')a=str[]-'A'+;
  70. else a=str[]-'a'+;
  71. if(str[]<='Z')b=str[]-'A'+;
  72. else b=str[]-'a'+;
  73. G[a][b]++;
  74. G[b][a]++;
  75. du[a]++;
  76. du[b]++;
  77. s=min(a,b);
  78. }
  79. int cnt=;
  80. FFor(i,,)
  81. {
  82. if(du[i]&&du[i]%)
  83. {
  84. s=i;
  85. cnt++;
  86. }
  87. if(cnt>)
  88. {
  89. cout<<"No Solution";
  90. return ;
  91. }
  92. }
  93. dfs(s);
  94.  
  95. while(!S.empty())
  96. {
  97. int x=S.top();
  98. if(x<=)cout<<char('A'+x-);
  99. else cout<<char('a'+x-);
  100. S.pop();
  101. }
  102.  
  103. return ;
  104. }

P1341 无序字母对的更多相关文章

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

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

  2. 洛谷P1341 无序字母对(欧拉回路)

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

  3. 洛谷 P1341 无序字母对(欧拉路)

    P1341 无序字母对 题目提供者yeszy 标签 福建省历届夏令营 难度 提高+/省选- 最新讨论 题目描述 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造 ...

  4. P1341 无序字母对【欧拉路径】- Hierholzer模板

    P1341 无序字母对 提交 24.87k 通过 6.80k 时间限制 1.00s 内存限制 125.00MB 题目提供者yeszy 难度提高+/省选- 历史分数100 提交记录 查看题解 标签 福建 ...

  5. P1341 无序字母对(欧拉回路)

    题目链接: https://www.luogu.org/problemnew/show/P1341 题目描述 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造一 ...

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

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

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

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

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

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

  9. P1341 无序字母对[欧拉路]

    题目描述 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造一个有n+1个字母的字符串使得每个字母对都在这个字符串中出现. 解析 毒瘤字符串读入 我就是不喜欢邻接 ...

随机推荐

  1. linux vim 行缩进,批量移动多行

    显示行号用::set nu :49>5  从第49行开始,连接5行右移一个tab. :49,93>   从第49行开始到93行右移一个tab 选中多行,然后移动 https://jingy ...

  2. 【代码笔记】iOS-长条label

    一,效果图. 二,代码. ViewController.m - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup ...

  3. JavaSE——网络编程基础知识

    计算机网络的分类: 局域网(LAN) 指在一个较小地理范围内的各种计算机网络设备互联在一起的通信网络,可以包括一个或多个子网,通常局限在几千米的范围之内. 城域网(MAN) 主要由城域范围内的各个局域 ...

  4. 网络基础 HTTP协议之http url简介

    HTTP协议之http url简介 by:授客 QQ:1033553122 http url简介 http url通过http协议,用于定位网络资源,是一种特殊类型的URI(统一资源定位) http_ ...

  5. 从ibd文件获取表空间id

    xtrabackup恢复过程中出现如下错误 InnoDB: Doing recovery: scanned up to log sequence number ( %) InnoDB: Doing r ...

  6. Mbps Mb M Kb如何换算

    在传输单位的写法上,B 和 b 分别代表 Bytes 和 bits,两者的定义是不同的,具体换算公式如下:1 Byte = 8 bits 1 Kb = 1024 bits 1 KB = 1024 by ...

  7. xp_readerrorlog与sp_readerrorlog

    SQL SERVER 可以使用xp_readerrorlog 或者sp_readerrorlog来查看错误日志. xp_readerrorlog 一共有七个参数: 1. 存档编号 2. 日志类型(1为 ...

  8. 基元用户模式构造--互锁构造 Interlocked 实现的异步web请求实例

    using System; using System.Collections.Generic; using System.Linq; using System.Net.Http; using Syst ...

  9. 为MySQ启用HugePage

    8.12.4.2 Enabling Large Page Support Some hardware/operating system architectures support memory pag ...

  10. sql注入--mysql

    mysql数据库结构: 数据库A  --> 表名  --> 列名 --> 数据 数据库B  --> 表名  --> 列名 --> 数据 mysql数据库信息: my ...