CF 508D Tanya and Password(无向图+输出欧拉路)
//不知道为什么,用scanf输入char数组的话,字符获取失效
//于是改用cin>>string,就可以了
//这题字符的处理比较麻烦,输入之后转成数字,用到函数get(char),get_num(string,int)
//最后字符的输出是反向输出的,用到函数get_char(int)
//这道题也算是到无向图输出欧拉路的模板题,判有无欧拉路用到函数ok()
#include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<cstring>
#include<string>
#include<cstdlib>
#include<vector>
#include<stack>
using namespace std;
typedef long long ll;
const int MAXN=200010; struct node
{
int next; //E[i].next指向图中与i同父的下一个结点
int to; //E[i].to指向图中i的子结点
}E[MAXN]; int vis[MAXN],fa[MAXN]; //vis:两字符构成串映射的点
int in[MAXN/2],ans[MAXN];
int cnt,pcnt,n,st,flag1,flag2; //cnt:边下标 pcnt:点下标 n:串数 st:图遍历的起点 void add(int u,int v)
{
E[cnt].to=v;
E[cnt].next=fa[u];
fa[u]=cnt++;
return ;
} int get(char s)
{
if(s>='0'&&s<='9') return s-'0';
else if(s>='a'&&s<='z') return s-'a'+10;
else return s-'A'+36;
} int get_num(string s,int index)
{
if(index==0)
return get(s[0])*100+get(s[1]);
else
return get(s[1])*100+get(s[2]);
} char get_char(int x)
{
if(x<10) return x+'0';
if(x<36) return x-10+'a';
return x-36+'A';
} void init()
{
scanf("%d",&n);
cnt=0;pcnt=0;
memset(fa,-1,sizeof(fa));
memset(vis,-1,sizeof(vis));
memset(in,0,sizeof(in));
string str; for(int i=0;i<n;i++)
{
cin>>str;
int u=get_num(str,0);
int v=get_num(str,1);
add(u,v); if(vis[u]==-1) //vis[u]记录边权为u的点是第几个被访问的
{
vis[u]=pcnt;
ans[pcnt++]=u; //点下标++
}
if(vis[v]==-1)
{
vis[v]=pcnt;
ans[pcnt++]=v;
}
//边1从vis[u]点连出,边2从vis[v]点连入
in[vis[u]]++; //第vis[u]个点的度++
in[vis[v]]--;
}
} void DFS(int x)
{
for(int i=fa[x];i!=-1;i=fa[x])
{
if(vis[i]==0)
{
vis[i]=1;
fa[x]=E[i].next;
DFS(E[i].to);
}
}
ans[pcnt++]=x;
} bool ok()
{
int i;
flag1=0,flag2=0;
for(i=0;i<pcnt;i++)
{
if(in[i]<-1||in[i]>1) //<-1表示入度大于1,>1表示出度大于1
break; //此时此图一定无法形成欧拉路
if(in[i]==1)
flag1++;
if(in[i]==-1)
flag2++;
}
if(i<pcnt || !(flag1==flag2 && flag1<=1))
return false;
else
return true;
} int main()
{
init(); if(ok())
{
st=ans[0];
for(int i=0;i<pcnt;i++)
if(in[i]==1)
st=ans[i]; //st记录图起点
pcnt=0;
memset(vis,0,sizeof(vis)); //以上找起点、清零是为DFS做准备
DFS(st);
if(pcnt<n+1)
printf("NO\n");
else
{
printf("YES\n");
printf("%c%c",get_char(ans[pcnt-1]/100),get_char(ans[pcnt-1]%100));
for(int i=pcnt-2;i>=0;i--)
printf("%c",get_char(ans[i]%100));
printf("\n");
}
}
else
printf("NO\n");
return 0;
}
CF 508D Tanya and Password(无向图+输出欧拉路)的更多相关文章
- POJ 2513 trie树+并查集判断无向图的欧拉路
生无可恋 查RE查了一个多小时.. 原因是我N define的是250500 应该是500500!!!!!!!!! 身败名裂,已无颜面对众人.. 吐槽完了 我们来说思路... 思路: 判有向图能否形成 ...
- CodeForces - 508D Tanya and Password(欧拉通路)
Description While dad was at work, a little girl Tanya decided to play with dad characters. She has ...
- codeforces 508D . Tanya and Password 欧拉通路
题目链接 给你n个长度为3的子串, 这些子串是由一个长度为n+2的串分割得来的, 求原串, 如果给出的不合法, 输出-1. 一个欧拉通路的题, 将子串的前两个字符和后两个字符看成一个点, 比如acb, ...
- poj2513(无向图判欧拉路)
链接:id=2513">点击打开链接 题意:一堆木棍左右两端涂有颜色,同样颜色的能够连接在一起,问全部木棍是否能都连上 代码: #include <map> #includ ...
- hiho48 : 欧拉路·一
时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho最近在玩一个解密类的游戏,他们需要控制角色在一片原始丛林里面探险,收集道具,并找到最后的宝藏.现在他们控制的 ...
- [hihoCoder] 第四十九周: 欧拉路·一
题目1 : 欧拉路·一 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho最近在玩一个解密类的游戏,他们需要控制角色在一片原始丛林里面探险,收集道具,并找到最 ...
- hiho一下 第四十九周 欧拉路·一
[题目链接]:click here~~ 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描写叙述 小Hi和小Ho近期在玩一个解密类的游戏.他们须要控制角色在一片原始丛林里面探险 ...
- 【HIHOCODER 1176】 欧拉路·一
描述 小Hi和小Ho最近在玩一个解密类的游戏,他们需要控制角色在一片原始丛林里面探险,收集道具,并找到最后的宝藏.现在他们控制的角色来到了一个很大的湖边.湖上有N个小岛(编号1..N),以及连接小岛的 ...
- POJ1386Play on Words[有向图欧拉路]
Play on Words Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 11846 Accepted: 4050 De ...
随机推荐
- ubuntu 16.04下搭建web服务器(MySQL+PHP+Apache) 教程
1.开始说明 下面很多可能参照网上其中以为前辈的,但有所改进吧.这些设置可能会有所不同,你需要根据不同情况进行修改. 安装apache2 2.切换管理员身份 在ubuntu中需要用root身份进行操作 ...
- 设计模式 --迭代器模式(Iterator)
能够游走于聚合内的每一个元素,同时还可以提供多种不同的遍历方式. 基本概念: 就是提供一种方法顺序访问一个聚合对象中的各个元素,而不是暴露其内部的表示. 使用迭代器模式的优点: 遍历集合或者数 ...
- PHP高效获取远程图片尺寸和大小
/** * 获取远程图片的宽高和体积大小 * * @param string $url 远程图片的链接 * @param string $type 获取远程图片资源的方式, 默认为 curl 可选 f ...
- String类之substring--->查找某位置对应的字
以下方法都是java内置类String类的内置方法(不是构造方法哦,就是普通的方法),不需要我们写,直接拿过来用即可. substring方法对应Api介绍 查找字符串中的 从int beginI ...
- OpenGL 茶壶
void MyRenderer::Init_Teapot_VBO() { m_fun->glGenBuffers(, &m_teapot_vbo); m_fun->glBindBu ...
- Dubbo协议与连接控制
协议参考手册 (+) (#) 推荐使用Dubbo协议 性能测试报告各协议的性能情况,请参见:性能测试报告 (+) dubbo:// (+) (#) Dubbo缺省协议采用单一长连接和NIO异步通讯,适 ...
- HDU 3835 R(N)(枚举)
题目链接 Problem Description We know that some positive integer x can be expressed as x=A^2+B^2(A,B are ...
- ESFramework 4.0 快速上手(06) -- Rapid引擎(续)
<ESFramework 4.0 快速上手>系列介绍的都是如何使用Rapid引擎(快速引擎) -- RapidServerEngine 和 RapidPassiveEngine.其实,大家 ...
- 把对象转换成map
public static Map toMap(Object object){ Map _result = new CaseInsensitiveMap(); if (object != null) ...
- WTL中菜单栏及工具栏项状态改变应注意的地方
WTL中菜单栏项和工具栏按钮的状态可通过UISetCheck(int ITEM_ID, int STATE)进行设置 需要注意的是要将需要改变状态的控件ID添加到UI更新映射中 /* MainFram ...