POJ 1386 Play on Words(单词建图+欧拉通(回)路路判断)
题目链接:http://poj.org/problem?id=1386
题目大意:给你若干个字符串,一个单词的尾部和一个单词的头部相同那么这两个单词就可以相连,判断给出的n个单词是否能够一个接着一个全部连通。
解题思路:其实就是让你判断是否是欧拉回路或欧拉通路,建图需要一点思维,把26个字母当成是节点,每个单词当成是一条有向边。比如单词possible就是一条p->e的有向边。
代码:
#include<iostream>
#include<cstdio>
#include<queue>
#include<cstring>
#define CLR(arr,val) memset(arr,val,sizeof(arr))
using namespace std;
const int N=; int indeg[N],outdeg[N],root[N]; int find(int x){
return root[x]==x?x:root[x]=find(root[x]);
} void init(){
CLR(indeg,);
CLR(outdeg,);
for(int i=;i<;i++)
root[i]=i;
} int main(){
int n,t;
scanf("%d",&t);
while(t--){
init();
scanf("%d",&n);
char str[];
for(int i=;i<=n;i++){
int u,v;
scanf("%s",str);
//u->v的有向边
u=str[]-'a';
v=str[strlen(str)-]-'a';
if(find(u)!=find(v))
root[find(u)]=find(v);
indeg[v]++;
outdeg[u]++;
}
bool flag=true;
int cnt=,chu=,ru=;
for(int i=;i<;i++){
if(find(i)==i&&(indeg[i]+outdeg[i])>)
cnt++;
if(indeg[i]!=outdeg[i]){
if(indeg[i]-==outdeg[i])
ru++;
else if(indeg[i]+==outdeg[i])
chu++;
else
flag=false;
}
}
//欧拉回路和通路都符合题目条件
if(flag&&cnt==&&(chu==&&ru==||chu==&&ru==))
puts("Ordering is possible.");
else
puts("The door cannot be opened.");
}
return ;
}
POJ 1386 Play on Words(单词建图+欧拉通(回)路路判断)的更多相关文章
- POJ 1386 Play on Words(有向欧拉通路 连通图)
		
题意 见下方中文翻译 每一个单词能够看成首尾两个字母相连的一条边 然后就是输入m条边 推断是否能构成有向欧拉通路了 有向图存在欧拉通路的充要条件: 1. 有向图的基图连通: 2. 全部点的出度和 ...
 - poj 1149 Pigs 网络流-最大流 建图的题目(明天更新)-已更新
		
题目大意:是有M个猪圈,N个顾客,顾客要买猪,神奇的是顾客有一些猪圈的钥匙而主人MIRKO却没有钥匙,多么神奇?顾客可以在打开的猪圈购买任意数量的猪,只要猪圈里有足够数量的猪.而且当顾客打开猪圈后mi ...
 - poj 3281 Dining 网络流-最大流-建图的题
		
题意很简单:JOHN是一个农场主养了一些奶牛,神奇的是这些个奶牛有不同的品味,只喜欢吃某些食物,喝某些饮料,傻傻的John做了很多食物和饮料,但她不知道可以最多喂饱多少牛,(喂饱当然是有吃有喝才会饱) ...
 - POJ 2226 最小点覆盖(经典建图)
		
Muddy Fields Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8881 Accepted: 3300 Desc ...
 - POJ  2195   一人一房    最小费用流  建图  水题
		
Going Home Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 21010 Accepted: 10614 Desc ...
 - POJ 2312Battle City(BFS-priority_queue 或者是建图spfa)
		
/* bfs搜索!要注意的是点与点的权值是不一样的哦! 空地到空地的步数是1, 空地到墙的步数是2(轰一炮+移过去) 所以用到优先队列进行对当前节点步数的更新! */ #include<iost ...
 - POJ 1161 Walls(Floyd , 建图)
		
题意: 给定n个城市, 然后城市之间会有长城相连, 长城之间会围成M个区域, 有L个vip(每个vip会处于一个城市里)要找一个区域聚会, 问一共最少跨越多少个长城. 分析: 其实这题难就难在建图, ...
 - [poj 3678]Katu Pazzle[2-SAT常用建图法]
		
题意: 不说了..典型的2-SAT 常用模型: 重点: 突出"绑定性". 连线表示限制而非可行. 因为最后要求对立点不在同一强连通分量是说同一强连通中的点必须同时选. 坑: 首先是 ...
 - POJ 1386 Play on Words(欧拉图的判断)
		
Play on Words Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 11838 Accepted: 4048 De ...
 
随机推荐
- 【转】大数据分析(Big Data OLAP)引擎Dremel, Tenzing 以及Impala
			
引自:http://blog.csdn.net/xhanfriend/article/details/8434896 对于数据分析师来说,SQL是主要的语言. Hive为Hadoop提供了支持SQL运 ...
 - 【BZOJ4540】【HNOI2016】序列(莫队)
			
[BZOJ4540][HNOI2016]序列(莫队) 题面 BZOJ 洛谷 Description 给定长度为n的序列:a1,a2,-,an,记为a[1:n].类似地,a[l:r](1≤l≤r≤N)是 ...
 - BZOJ1367 [Baltic2004]sequence  【左偏树】
			
题目链接 BZOJ1367 题解 又是一道神题,, 我们考虑一些简单的情况: 我们先假设\(b_i\)单调不降,而不是递增 对于递增序列\(\{a_i\}\),显然答案\(\{b_i\}\)满足\(b ...
 - BZOJ4735 你的生命已如风中残烛  【数学】
			
题目链接 BZOJ4735 题解 给定一个序列,有的位置为\(w_i - 1\),有的位置为\(-1\),问有多少种排列,使得任意前缀和非负? 我们末尾加上一个\(-1\),就是要保证除了末尾外的前缀 ...
 - Linux内核分析5
			
周子轩 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 一.学习总结 通过gdb ...
 - 【learning】矩阵树定理
			
问题描述 给你一个图(有向无向都ok),求这个图的生成树个数 一些概念 度数矩阵:\(a[i][i]=degree[i]\),其他等于\(0\) 入度矩阵:\(a[i][i]=in\_degree[i ...
 - Linux基础-正则表达式整理---------------grep、sed、awk
			
目录: Ⅰ:正则表达式 Ⅱ:作业 Ⅰ:正则表达式 正则就是用一些具有特殊含义的符号组合到一起(称为正则表达式)来描述字符或者字符串的方法.或者说:正则就是用来描述一类事物的规则. 在lin ...
 - activiti学习-用户与用户组
			
activiti学习笔记3-用户与用户组 2015年05月07日 14:43:06 cq1982 阅读数:4142更多 个人分类: activiti工作流引擎 (本博客都是纯文本手工代码,错误难免 ...
 - selenium - Select类 - 下拉框
			
WebDriver提供了Select类来处理下拉框. 如百度搜索设置的下拉框,如下图: from selenium import webdriver from selenium.webdriver.s ...
 - UESTC--1730
			
原题链接:http://acm.uestc.edu.cn/problem.php?pid=1730 分析:线段树单点更新,区间求和. #include<iostream> #include ...