题意:

      给一些单词,问是否可以每个单词只用一次,然后连接在一起(不一定要成环,能连接在一起就行)。

思路:

      这个题目的入手点比较好想,其实就是问欧拉路径,先说下解题步骤,然后在细说

(1) 把每个单词看成一条边,单词的首字母和尾字母是点

(2) 然后记录入度,出度,根据入度出度判断是不是欧拉路径或者回路

(3) 别往了判断所有点是不是属于同一个连通子集,这个可以用并查集啥的

(4) 把所有的边都排序下,至于是什么顺序,根据自己的存图方式去排

(5) 欧拉路径就从头开始(要是欧拉回路就找个最小的点)深搜找出路径

     之前也没写过输出欧拉路径啥的啊!看有人说可以用栈递归存边,然后就在纸上画了几个8想想,觉得有道理,就自己写了一个欧拉路的(其实很简单),至于排序的地方,我想的是直接在存边之前先把边排序下,因为欧拉路径输出的时候也是比较简单“画6的感觉”,要求字典序最小,因为我用的是前向星,其实这个东西建边是倒叙的,就是a-b a-c a-d 的顺序进去,那么访问的时候是a-d,a-c,a-b这样的,全都是抱着试一试,结果直接a了。虽然是简单题,但是挺高兴啊。


#include<stack>
#include<stdio.h>
#include<string.h>
#include<algorithm> #define N_node 30
#define N_edge 1000 + 100 using namespace std; typedef struct
{
int to ,next;
}STAR; typedef struct
{
char str[30];
}EDGE; STAR E[N_edge];
EDGE edge[N_edge];
int list[N_node] ,tot;
int mer[N_node];
int mark[N_edge];
int deg[N_node];
stack<int>mysk; bool camp(EDGE a ,EDGE b)
{
return strcmp(a.str ,b.str) > 0;
} void add(int a ,int b)
{
E[++tot].to = b;
E[tot].next = list[a];
list[a] = tot;
} int finds(int x)
{
return x == mer[x] ? x : mer[x] = finds(mer[x]);
} void DFS(int s)
{
for(int k = list[s] ;k ;k = E[k].next)
{
if(mark[k]) continue;
mark[k] = 1;
DFS(E[k].to);
mysk.push(k);
}
} int main ()
{
int t ,n ,i ,j;
int mkc[30];
scanf("%d" ,&t);
while(t--)
{
scanf("%d" ,&n);
memset(deg ,0 ,sizeof(deg));
memset(mkc ,0 ,sizeof(mkc));
for(i = 1 ;i <= 26 ;i ++)
mer[i] = i;
for(i = 1 ;i <= n ;i ++)
{
scanf("%s" ,edge[i].str);
int a = edge[i].str[0] - 'a' + 1;
int b = edge[i].str[strlen(edge[i].str)-1] - 'a' + 1;
mer[finds(a)] = finds(b);
mkc[a] = mkc[b] = 1;
deg[a] ++;
deg[b] --;
} int s = 0 ,z = 0 ,f = 0 ,min;
for(i = 1 ;i <= 26 ;i ++)
{
if(mkc[i])
{
if(mer[i] == i) s ++;
if(!deg[i]) continue;
if(deg[i] == 1)
z ++ ,min = i;
else if(deg[i] == -1) f ++;
else s ++;
}
} if(s != 1 || f + z != 0 && f + z != 2)
{
printf("***\n");
continue;
} sort(edge + 1 ,edge + n + 1 ,camp);
memset(list ,0 ,sizeof(list));
tot = 1;
for(i = 1 ;i <= n ;i ++)
{
int a = edge[i].str[0] - 'a' + 1;
int b = edge[i].str[strlen(edge[i].str)-1] - 'a' + 1;
add(a ,b);
} if(z + f == 0) min = edge[n].str[0] - 'a' + 1; while(!mysk.empty())
mysk.pop();
memset(mark ,0 ,sizeof(mark));
DFS(min); while(!mysk.empty())
{
int tou = mysk.top();
mysk.pop();
if(mysk.empty())
printf("%s\n" ,edge[tou-1].str);
else printf("%s." ,edge[tou-1].str);
}
}
return 0;
}

POJ2337 欧拉路径字典序输出的更多相关文章

  1. ZOJ 3204 Connect them(字典序输出)

    主要就是将最小生成树的边按字典序输出. 读取数据时,把较小的端点赋给u,较大的端点号赋值给v. 这里要用两次排序,写两个比较器: 第一次是将所有边从小到大排序,边权相同时按u从小到大,u相同时按v从小 ...

  2. poj 1041(字典序输出欧拉回路)

    John's trip Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8641   Accepted: 2893   Spe ...

  3. 二叉排序树:HUD3999-The order of a Tree(二叉排序树字典序输出)

    The order of a Tree Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...

  4. poj 1041 John's trip——欧拉回路字典序输出

    题目:http://poj.org/problem?id=1041 明明是欧拉回路字典序输出的模板. 优先队列存边有毒.写跪.学习学习TJ发现只要按边权从大到小排序连边就能正常用邻接表了! 还有一种存 ...

  5. UVA 796 - Critical Links 无向图字典序输出桥

    题目:传送门 题意:给你一个无向图,你需要找出里面的桥,并把所有桥按字典序输出 这一道题就是用无向图求桥的模板就可以了. 我一直错就是因为我在输入路径的时候少考虑一点 错误代码+原因: 1 #incl ...

  6. 拓扑排序详解(梅开二度之dfs版按字典序输出拓扑路径+dfs版输出全部拓扑路径

    什么是拓扑排序? 先穿袜子再穿鞋,先当孙子再当爷.这就是拓扑排序! 拓扑排序说白了其实不太算是一种排序算法,但又像是一种排序(我是不是说了个废话qwq) 他其实是一个有向无环图(DAG, Direct ...

  7. poj2337 欧拉路径

    poj2337 这道题昨天晚上开始做,今天才A.但是问题想透了, 发现其实没那么难 题目大意: 给你一些单词,如果一个单词的末尾字符与另一个单词首字符相同,则两个的单词可以连接.问是否可以把所有单词连 ...

  8. poj-2337(欧拉回路输出)

    题意:给你n个字符串,每个字符串可以和另一个字符串连接的前提是,前一个字符串的尾字符等于后一个字符串的首字符,问你存不存在欧拉通路并输出 解题思路:基本标准流程,建图:把一个字符串可以看作一条首字符指 ...

  9. [poj2337]求字典序最小欧拉回路

    注意:找出一条欧拉回路,与判定这个图能不能一笔联通...是不同的概念 c++奇怪的编译规则...生不如死啊... string怎么用啊...cincout来救? 可以直接.length()我也是长见识 ...

随机推荐

  1. CCF(元素选择器:50分):字符串+模拟

    元素选择器 201809-3 这里我只考虑了没有后代选择器的情况 #include<iostream> #include<cstdio> #include<cstring ...

  2. HDOJ-6645(简单题+贪心+树)

    Stay Real HDOJ-6645 由小根堆的性质可以知道,当前最大的值就在叶节点上面,所以只需要排序后依次取就可以了. #include<iostream> #include< ...

  3. 数据采集组件:Flume基础用法和Kafka集成

    本文源码:GitHub || GitEE 一.Flume简介 1.基础描述 Flume是Cloudera提供的一个高可用的,高可靠的,分布式的海量日志采集.聚合和传输的系统,Flume支持在日志系统中 ...

  4. 2.2 Python3基础-基本数据类型

    >>返回主目录 源代码 # 基本数据类型 # Number类型:如何查看变量的数据类型? name = 'Portos' print(type(name)) # 结果:str print( ...

  5. Python接口测试-保持登录状态

    #coding:utf-8import requestsimport json#登录url ="https://passport.cnblogs.com/user/signin"h ...

  6. editplus更改编码

    1.在Tools下拉后选择Configure User Tools 2.在左边导航菜单找到File,对应右边视图中的Default encoding 3.将编码更改为utf-8,点击底部的OK保存.

  7. 手把手教你DNS劫持挂马

    出品|MS08067实验室(www.ms08067.com) 本文作者:BlackCat(Ms08067内网安全小组成员) 首先学习DNS劫持之前,务必要了解下DNS是个什么玩意. DNS(域名系统) ...

  8. 【数据结构与算法】——链表(Linked List)

    链表(Linked List)介绍 链表是有序的列表,但是它在内存中是存储如下: 链表是以节点的方式来存储的,是链式存储. 每个节点包含data域,next域:指向下一个节点. 如图:链表的各个节点不 ...

  9. C语言可变参函数分析

    code[class*="language-"], pre[class*="language-"] { color: rgba(51, 51, 51, 1); ...

  10. 使用Drone构建Docker映像

    使用Drone构建Docker映像 实践所用软件: Git Gogs Drone Docker 私有镜像仓库 实践链接:https://www.katacoda.com/courses/cicd/bu ...