hdu 1116
欧拉回路,利用并查集来实现;
代码:
![](https://images.cnblogs.com/OutliningIndicators/ContractedBlock.gif)
#include<cstdio> #include<cstring> #include<vector> using namespace std; int a[30],f[30],b[30]; bool vis[30]; int find(int x) { return f[x]==-1?x:f[x]=find(f[x]); } void combine(int x,int y) { int n=find(x); int m=find(y); if(n!=m) f[n]=m; } bool oula() { int st=-1; for(int i=0; i<26; i++) { if(a[i]||b[i]) if(st==-1)st=find(i); else if(st!=find(i)) return false; } vector<int>v; for(int i=0; i<26; i++) if(a[i]!=b[i]) v.push_back(a[i]-b[i]); return v.size()==0||v.size()==2&&v[1]*v[0]==-1; } int main() { int t,n; char s[1009]; scanf("%d",&t); while(t--) { memset(a,0,sizeof a); memset(f,-1,sizeof f); memset(b,0,sizeof b); int ans=0,cnt=0; bool flag=1; scanf("%d",&n); for(int i=0; i<n; i++) { scanf("%s",&s); int l=strlen(s); int x=s[0]-'a',y=s[l-1]-'a'; a[x]++,b[y]++; combine(x,y); } if(oula()) printf("Ordering is possible.\n"); else puts("The door cannot be opened."); } return 0; }
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步