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 ...
随机推荐
- 关于PHP的一小段代码求解如下求解"%2\$s"
<?php$format = "The %2\$s contains %1\$d monkeys";printf($format, 8, "北京");?& ...
- QTP脚本汇总比较有价值
1.Object Spy的Tips Hold the CTRL key to change the window focus or perform other mouse operations 2. ...
- JVM内存模型,垃圾回收算法
JVM内存模型总体架构图 程序计数器多线程时,当线程数超过CPU数量或CPU内核数量,线程之间就要根据时间片轮询抢夺CPU时间资源.因此每个线程有要有一个独立的程序计数器,记录下一条要运行的指令.线程 ...
- hadoop 2.2.0 关于map和reduce的个数的设置
关于hadoop中的map过程,我的理解是每一个map系统会开启一个JVM进程来处理,map之间相互并行,map函数内串行.这样的想法是否正确? 由于想在hadoop集群上算一个初始输入数据不多,但是 ...
- LYF电子书制作工具(CHM格式)
可以制作CHM电子书 可以制作电子相册 下载地址:http://files.cnblogs.com/files/blogLYF/LYF电子书制作安装包.zip http://files.cnblogs ...
- JSON.parse() JSON.stringify() eval() jQuery.parseJSON() 的区别
http://www.jb51.net/article/81880.htm : jQuery.parseJSON(jsonString) : 将格式完好的JSON字符串转为与之对应的Java ...
- MySQL设置binlog日志的有效期自动回收
设置日志保留天数,到期后自动删除 查看当前日志保存天数: show variables like '%expire_logs_days%'; 默认是0,即永不过期. 通过设置全局参数修改: set g ...
- SQL learning
一.创建和删除数据库 1.创建用户 //创建用户且置密码,在MySQL中行,但在Oracle中行 ----必须在超级管理员身份下操作 create user hncu identified by ' ...
- 《Windows编程循序渐进》——进度条
界面布局如下:
- html5权威指南:html全局属性
html全局属性:http://www.w3school.com.cn/tags/html_ref_standardattributes.asp 辅助记忆:(ail1,s2,c3,t3,d4)(acd ...