题目描述
给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒)。请构造一个有n+1个字母的字符串使得每个字母对都在这个字符串中出现。
输入输出格式
输入格式:
第一行输入一个正整数n。
以下n行每行两个字母,表示这两个字母需要相邻。
输出格式:
输出满足要求的字符串。
如果没有满足要求的字符串,请输出“No Solution”。
如果有多种方案,请输出前面的字母的ASCII编码尽可能小的(字典序最小)的方案
考察的还是欧拉通路的问题,通过给出的点构建无向图,记录各个点的度数,若度数为奇数的点的个数不为0或2时,不能构成欧拉通路,返回No Solution,同时找到起点h后,进行递归找欧拉通路
#include<bits/stdc++.h>
#define ll long long
#define INF 0x3f3f3f3f
#define maxn 110
#define qx std::ios::sync_with_stdio(false)
#define N 2100
using namespace std;
int w[250][250],n,deg[250];
char a,b,reg[500];
void euler(int s){
for(int j = 0; j < 250; j++) {
if(w[s][j]) {
w[s][j] = w[j][s] = 0;
euler(j);
}
}
reg[n--] = s;
}
int main(){
cin>>n;
for(int i=0;i<n;i++){
cin>>a>>b;
w[a][b]=w[b][a]=1;
deg[a]++;
deg[b]++;
}
char h=0;int c=0;
for(int i=0;i<250;i++){
if(deg[i]&1){
c++;
if(!h) h = i;
}
}
if(!h)
for(int i = 0; i < 250; i++)
if(deg[i]) {
h = i;
break;
}
if(c && c != 2) return puts("No Solution"), 0; // 判断无解
euler(h);
cout<<reg;
return 0;
}