【例题 6-16 UVa 10129】Play on Words
【链接】  我是链接,点我呀:) 
 【题意】
在这里输入题意
【题解】
入度减去出度个数为1的点和为-1的点各有1个,然后其他点入度减去出度为0
或者全都是入度为0的点即可。
【代码】
#include <bits/stdc++.h>
using namespace std;
const int N = 300;
int n,du[N];
map <char,int> mmap;
int f[N+10];
bool bo[N+10];
int ff(int x){
 	if (f[x]==x) return x;
 	else return f[x] =  ff(f[x]);
}
int main(){
	#ifdef LOCAL_DEFINE
	    freopen("F:\\c++source\\rush_in.txt", "r", stdin);
	#endif
	ios::sync_with_stdio(0),cin.tie(0);
	int T;
	cin >> T;
	while (T--){
		memset(du,0,sizeof du);
		memset(bo,0,sizeof bo);
		for (int i = 'a';i <= 'z';i++)
			f[i] = i;
	 	cin >> n;
	 	string s;
	 	for (int i = 1;i <=n;i++){
	 	 	cin >> s;
	 	 	int x = s[0],y = s[(int) s.size()-1];
	 	 	du[(int) s[0]]++;
	 	 	du[(int) s[(int) s.size()-1]]--;
	 	 	bo[(int) s[0]] = true;
	 	 	bo[(int) s[(int) s.size()-1]] = true;
	 	 	if (ff(x)!=ff(y)){
	 	 	 	f[ff(x)] = ff(y);
	 	 	}
	 	}
	 	bool ok = true;
	 	int idx = 'a';
		for (int i = 'a';i <= 'z';i++)
			if (bo[i]){
			 	idx = ff(i);
			}
		for (int i = 'a';i <= 'z';i++)
			if (bo[i]&& ff(i)!=idx)
				ok = false;
		if (!ok){
		 cout <<"The door cannot be opened."<<endl;
		 continue;
		}
		int fi1 = 0,fi2 = 0;
	 	for (int i = 'a';i <= 'z';i++)
	 		if (du[i]==-1)
	 			fi1++;
	 		else if (du[i]==1){
	 		    	fi2++;
	 			}else if (du[i]!=0) fi1 = 2;
		if ((fi1==1 && fi2==1) || (fi1==0 && fi2==0)){
			cout << "Ordering is possible." << endl;
	    }else cout <<"The door cannot be opened."<<endl;
	}
	return 0;
}
												
											【例题 6-16 UVa 10129】Play on Words的更多相关文章
- Play on Words UVA - 10129 欧拉路径
		
关于欧拉回路和欧拉路径 定义:欧拉回路:每条边恰好只走一次,并能回到出发点的路径欧拉路径:经过每一条边一次,但是不要求回到起始点 ①首先看欧拉回路存在性的判定: 一.无向图每个顶点的度数都是偶数,则存 ...
 - 【例题 6-15 UVA - 10129】Play on Words
		
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 拓扑大水题 [代码] #include <bits/stdc++.h> using namespace std; con ...
 - Uva 10129 单词
		
题目链接:https://uva.onlinejudge.org/external/101/10129.pdf 把单词的首字母和最后一个字母看做节点,一个单词就是一个有向边.有向图的欧拉定理,就是除了 ...
 - UVa 10129单词(欧拉回路)
		
https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
 - Uva 10129 - Play on Words 单词接龙 欧拉道路应用
		
跟Uva 10054很像,不过这题的单词是不能反向的,所以是有向图,判断欧拉道路. 关于欧拉道路(from Titanium大神): 判断有向图是否有欧拉路 1.判断有向图的基图(即有向图转化为无向图 ...
 - uva 10129 play on words——yhx
		
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABNUAAANeCAYAAAA1BjiHAAAgAElEQVR4nOydabWsuhaFywIasIAHJK
 - UVa 10129 (并查集 + 欧拉路径) Play on Words
		
题意: 有n个由小写字母的单词,要求判断是否存在某种排列使得相邻的两个单词,前一个单词末字母与后一个单词首字母相同. 分析: 将单词的两个字母看做节点,则一个单词可以看做一条有向边.那么题中所求的排列 ...
 - UVa 10129 Play On Words【欧拉道路 并查集 】
		
题意:给出n个单词,问这n个单词能否首尾接龙,即能否构成欧拉道路 按照紫书上的思路:用并查集来做,取每一个单词的第一个字母,和最后一个字母进行并查集的操作 但这道题目是欧拉道路(下面摘自http:// ...
 - UVA - 10129 Play on Words(欧拉回路+并查集)
		
2.解题思路:本题利用欧拉回路存在条件解决.可以将所有的单词看做边,26个字母看做端点,那么本题其实就是问是否存在一条路径,可以到达所有出现过的字符端点.由于本题还要求了两个单词拼在一起的条件是前一个 ...
 
随机推荐
- HDU——T 1251 统计难题
			
http://acm.hdu.edu.cn/showproblem.php?pid=1251 Time Limit: 4000/2000 MS (Java/Others) Memory Limi ...
 - 洛谷 P2690 接苹果
			
P2690 接苹果 题目背景 USACO 题目描述 很少有人知道奶牛爱吃苹果.农夫约翰的农场上有两棵苹果树(编号为1和2), 每一棵树上都长满了苹果.奶牛贝茜无法摘下树上的苹果,所以她只能等待苹果 从 ...
 - cogs 184. [USACO Oct08] 搭建篱笆
			
184. [USACO Oct08] 搭建篱笆 ★★ 输入文件:quad.in 输出文件:quad.out 简单对比时间限制:1 s 内存限制:128 MB 勤奋的农夫约翰想要修建一个 ...
 - [Python] Create a Log for your Python application
			
Print statements will get you a long way in monitoring the behavior of your application, but logging ...
 - SAR(遥感、卫星) 图像常用数据集
			
Brazilian Coffee Scenes数据集较小,5MB左右: UC Merced Land Use Dataset(数据集规模较大,300MB+) MSTAR public targets ...
 - 使用无线局域网(WLAN)更需要注意加强安全防范
			
下面链接介绍对WLAN的安全加密部分的内容,主要对WinAircrackPack工具的在Wlan方面的应用分析,介绍常见几种的加密方式,以及再使用无线设备时候的注意事项.650) thi ...
 - screen-调节屏幕亮度
			
今天做项目的时候,需要实现一个功能,就是进入一个应用,在这个应用中,屏幕的亮度变为最亮.关键代码如下 bt1.setOnClickListener(new OnClickListener() { @O ...
 - Android开发经验一判断当前屏幕是全屏还是非全屏
			
public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView ...
 - golang filepath.Glob
			
package main import ( "fmt" "path/filepath" ) func main() { //找出/home/ 目录下的所有的lo ...
 - Vue神之大坑处理:获取通过URL的的参数不可直接操作
			
比如: $router.query['isZero'] == 'false'; //不会生效,刷新页面又好使了.打印处理是蓝色的false,再次刷新字体就变浅黑了. 解决:($router.quer ...