ACM/ICPC 之 DFS求解欧拉通路路径(POJ2337)
判断是欧拉通路后,DFS简单剪枝求解字典序最小的欧拉通路路径
//Time:16Ms Memory:228K
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std; #define MAX 1005
#define MAXS 24 //姓名
#define MAXN 26 //字母 struct Edge{
char name[MAXS];
int a,b;
friend bool operator < (Edge &e1, Edge &e2)
{ return strcmp(e1.name, e2.name) < 0; }
}e[MAX]; int n;
int in[MAXN], out[MAXN]; //入度与出度
int order[MAX]; //顺序路径
bool v[MAX]; bool dfs(int x, int rk)
{
if(rk == n) return true;
for(int i = 0; i < n; i++)
{
if(!v[i] && x == e[i].a){
v[i] = true;
order[rk] = i;
if(dfs(e[i].b, rk+1)) return true;
v[i] = false;
}
}
return false;
} int main()
{
//freopen("in.txt","r",stdin); int T;
scanf("%d",&T);
while(T--){
memset(e,0,sizeof(e));
memset(in,0,sizeof(in));
memset(out,0,sizeof(out));
memset(order,-1,sizeof(order));
memset(v,false,sizeof(v));
scanf("%d",&n);
//构图
int st = 26; //st:起点
for(int i = 0; i < n; i++)
{
scanf("%s",e[i].name);
e[i].a = e[i].name[0] - 'a';
e[i].b = e[i].name[strlen(e[i].name) - 1] - 'a';
out[e[i].a]++;
in[e[i].b]++;
if(e[i].a < st) st = e[i].a;
}
sort(e,e+n);
//欧拉路判定
int odd = 0; //奇度结点个数
bool flag = true;
for(int i = 0 ; i < MAXN; i++)
{
if(in[i] != out[i])
{
odd++;
if(out[i] - in[i] == 1)
st = i;
else if(out[i] - in[i] != -1)
{
flag = false;
break;
}
}
}
if(flag && (odd ==2 || odd == 0) && dfs(st,0)) //满足欧拉通路(排除非连通)+完整路径(判断非连通)
{
for(int i = 0; i < n - 1; i++)
printf("%s.", e[order[i]].name);
printf("%s\n", e[order[n-1]].name);
}
else printf("***\n"); } return 0;
}
ACM/ICPC 之 DFS求解欧拉通路路径(POJ2337)的更多相关文章
- ACM/ICPC 之 DFS求解欧拉回路+打表(POJ1392)
本题可以通过全部n位二进制数作点,而后可按照某点A的末位数与某点B的首位数相等来建立A->B有向边,以此构图,改有向图则是一个有向欧拉回路,以下我利用DFS暴力求解该欧拉回路得到的字典序最小的路 ...
- hdu1116有向图判断欧拉通路判断
Play on Words Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) T ...
- 欧拉回路&欧拉通路判断
欧拉回路:图G,若存在一条路,经过G中每条边有且仅有一次,称这条路为欧拉路,如果存在一条回路经过G每条边有且仅有一次, 称这条回路为欧拉回路.具有欧拉回路的图成为欧拉图. 判断欧拉通路是否存在的方法 ...
- POJ 1386 Play on Words(有向欧拉通路 连通图)
题意 见下方中文翻译 每一个单词能够看成首尾两个字母相连的一条边 然后就是输入m条边 推断是否能构成有向欧拉通路了 有向图存在欧拉通路的充要条件: 1. 有向图的基图连通: 2. 全部点的出度和 ...
- POJ 1300 欧拉通路&欧拉回路
系统的学习一遍图论!从这篇博客开始! 先介绍一些概念. 无向图: G为连通的无向图,称经过G的每条边一次并且仅一次的路径为欧拉通路. 如果欧拉通路是回路(起点和终点相同),则称此回路为欧拉回路. 具有 ...
- poj 2513 连接火柴 字典树+欧拉通路 好题
Colored Sticks Time Limit: 5000MS Memory Limit: 128000K Total Submissions: 27134 Accepted: 7186 ...
- poj2513- Colored Sticks 字典树+欧拉通路判断
题目链接:http://poj.org/problem?id=2513 思路很容易想到就是判断欧拉通路 预处理时用字典树将每个单词和数字对应即可 刚开始在并查集处理的时候出错了 代码: #includ ...
- Colored Sticks POJ - 2513 并查集+欧拉通路+字典树hash
题意:给出很多很多很多很多个棒子 左右各有颜色(给出的是单词) 相同颜色的可以接在一起,问是否存在一种 方法可以使得所以棒子连在一起 思路:就是一个判欧拉通路的题目,欧拉通路存在:没奇度顶点 或者 ...
- POJ2513Colored Sticks(欧拉通路)(字典树)(并查集)
Colored Sticks Time Limit: 5000MS Memory ...
随机推荐
- hibernate4中取得connection的方法
在hibernate3中,使用了c3p0连接池,尝试了多种办法取得connection对象,以下两种可以使用. Java代码 Connection conn; // 方法1:hibernate4中将 ...
- editplus中使用emmet?
要用emmet生成html类型, 格式是: html:???, 意思是 都是html大类型, 小类型用冒号. 如:html:5, 或者全部都是! 则生成html5的类型文档. emmet是zen co ...
- acdream1421 TV Show (枚举)
http://acdream.info/problem?pid=1421 Andrew Stankevich Contest 22 TV Show Special JudgeTime Limit: 2 ...
- http request method and response codes
============================ HTTP_Method============================ HTTP Method Action Examples GET ...
- AngularJS 使用ngOption实现下拉列表
最近使用到了ngOption实现下拉选择列表,由于需要实现分组等功能,百度了下没有太好的文章,就百度到一篇英文的帖子,按照其中的代码很顺利的搞定了. 本篇根据文中代码,详细讲述下如何实现下拉列表 更多 ...
- Jquery Md5加密解密
首先需要调用md5解析的js文件.(右击-目标另存为方式下载) http://files.cnblogs.com/files/colinliu/md5.js 加密方法参考: <script ty ...
- hdu4751 Divide Groups
This year is the 60th anniversary of NJUST, and to make the celebration more colorful, Tom200 is goi ...
- js时间格式化(yy年MM月dd日 hh:mm)
//时间格式化 Date.prototype.format = function (format) { var o = { "M+": this.getMonth() + 1, / ...
- Dp~Hrbust1426( 集训队的晚餐 )
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAxsAAAPRCAYAAACVrbUbAAAgAElEQVR4nOzdW5Bcx33n+X7aiH3b2J
- 160809225_叶桦汀_C语言程序设计实验2 选择结构程序设计_进阶
#include<stdio.h> #include<math.h> int main() { int a,b,c,l,p,s; printf("请输入三个数:&qu ...