#2629. 航空路线
航空路线
题目描述
给定一张航空图,图中顶点代表城市,边代表两城市间的直通航线,并且不存在任何两个城市在同一条经线上。现要求找出一条满足下述限制条件的且途经城市最多的旅行路线。
1、从最西端城市出发,单向从西向东途经若干城市到达最东端城市,然后再单向从东向西飞回起点(可途经若干城市)。
2、除起点城市外,任何城市只能访问一次。
对于给定的航空图,试设计一个算法找出一条满足要求的最佳航空旅行路线。
输入格式
输入的第一行是用空格隔开的两个整数,分别代表航空图的点数 和边数 。
第 到第 行,每行一个字符串,第 行的字符串代表从西向东第 座城市的名字 。
第 到第 行,每行两个字符串 ,代表城市 和城市 之间存在一条直通航线。
输出格式
请首先判断是否存在满足要求的路线,若存在,请给出一种旅行的方案。
如果存在路线,输出格式为:
- 请在第一行输出一个整数 ,代表途径最多的城市数。
- 在第 到第 行,每行一个字符串,第 行的字符串代表旅行路线第 个经过的城市的名字。请注意第 和第 个城市必然是出发城市名。
否则请输出一行一个字符串 No Solution!
。
样例
样例输入 #1
8 9
Vancouver
Yellowknife
Edmonton
Calgary
Winnipeg
Toronto
Montreal
Halifax
Vancouver Edmonton
Vancouver Calgary
Calgary Winnipeg
Winnipeg Toronto
Toronto Halifax
Montreal Halifax
Edmonton Montreal
Edmonton Yellowknife
Edmonton Calgary
样例输出 #1
7
Vancouver
Edmonton
Montreal
Halifax
Toronto
Winnipeg
Calgary
Vancouver
提示
数据规模与约定
对于 的数据,保证 ,, 的长度不超过 ,且仅可能包含大小写字母与数字, 一定是输入中给出的城市名,且不会有同一组 被给出两次。
来源
P2770