博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UVA 10441 Catenyms 欧拉道路
阅读量:6956 次
发布时间:2019-06-27

本文共 2027 字,大约阅读时间需要 6 分钟。

// #pragma comment(linker, "/STACK:1024000000,1024000000")#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;typedef long long ll;typedef pair
pii;#define pb(a) push_back(a)#define INF 0x1f1f1f1f#define lson idx<<1,l,mid#define rson idx<<1|1,mid+1,rvoid debug(){#ifdef ONLINE_JUDGE#else freopen("d:\\in.txt","r",stdin); freopen("d:\\out1.txt","w",stdout);#endif}char getch(){ char ch; while((ch=getchar())!=EOF) { if(ch!=' '&&ch!='\n')return ch; } return EOF;}struct point{ int x,y,dir,col, t; point() {} point (int a,int b,int c,int d,int e) { x=a; y=b; dir=c; col=d; t=e; }};int vis[1001];string dic[1001];stack
sta;int n;int f(int u){ for(int i=1;i<=n;i++)if(!vis[i]&&dic[i][0]==u+'a') { vis[i]=1; f(dic[i][dic[i].size()-1]-'a'); sta.push(i); } return 0;}int da[26];int cvis[26];int find(int a){ return a==da[a]?a:da[a]=find(da[a]);}int can(){ for(int i=0;i<26;i++)da[i]=i; memset(cvis,0,sizeof(cvis)); for(int i=1;i<=n;i++) { int fa=find(dic[i][0]-'a'); int fb=find(dic[i][dic[i].size()-1]-'a'); cvis[dic[i][0]-'a']=1;cvis[dic[i][dic[i].size()-1]-'a']=1; if(fa!=fb)da[fa]=fb; } int num=0; for(int i=0;i<26;i++) if(da[i]==i&&cvis[i]==1)num++; return num==1?1:0;}int main(){ int t; cin>>t; for(int ca=1;ca<=t;ca++) { cin>>n; int deg[26]={ 0}; for(int i=1;i<=n;i++) { cin>>dic[i]; } sort(dic+1,dic+1+n); for(int i=1;i<=n;i++) { deg[dic[i][0]-'a']++;deg[dic[i][dic[i].size()-1]-'a']--; } int in=-1,out=-1; int allzero=1; for(int i=0;i<26;i++) { if(deg[i]==1) { allzero=0; if(in!=-1) { in=-1;break; } else in=i; }else if(deg[i]==-1) { allzero=0; if(out!=-1) { out=-1;break; } else out=i; }else if(deg[i]!=0) { allzero=0; in=-1;out=-1;break; } } if(allzero) { in=dic[1][0]-'a';out=dic[1][0]-'a'; } if(in==-1||out==-1||!can()) { cout<<"***"<
View Code

 

转载于:https://www.cnblogs.com/BMan/p/3272446.html

你可能感兴趣的文章
MYSQL建表语法(主键,外键,联合主键)
查看>>
多线程的通信和同步(Java并发编程的艺术--笔记)
查看>>
Linux使用du和df查看磁盘和文件夹占用空间
查看>>
CentOS 6.6 MySQL install
查看>>
从零开始用gulp
查看>>
android之Activity的生命周期
查看>>
hadoop2.4 支持snappy
查看>>
STL 笔记(四) 迭代器 iterator
查看>>
2017"百度之星"程序设计大赛 - 复赛1003&&HDU 6146 Pokémon GO【数学,递推,dp】
查看>>
[LeetCode] Valid Parenthesis String 验证括号字符串
查看>>
各大SRC中的CSRF技巧
查看>>
Docker for Windows 使用入门
查看>>
【Django】Web应用开发经由
查看>>
SpringBoot(九)-- SpringBoot JDBC
查看>>
Spring + Mybatis - 原始dao开发整合 与 Mapper代理整合
查看>>
基于Centos搭建nginx+uwsgi运行django环境
查看>>
context switch
查看>>
Oracle awr报告生成操作步骤
查看>>
【DB2】DB2使用IMPORT命令导入含有自增长列的表报错处理
查看>>
微服务之springCloud-docker-comsumer(三)
查看>>