题意:俩头带有颜色的木棒,要求按颜色同的首尾相连,可能否?

思路:棒子本身是一条边,以俩端为顶点(同颜色共点),即求是否有无向图欧拉路(每条棒子只有一根,

边只能用一次,用一次边即选一次棒子)。

先判断图是否连通,并查集判断即可,有fa[i]==i的,表示“根”,连通图只能有一个这样根,大于1不连通。

在判断欧了图是否存在,度权为偶数或者只有2俩奇数为欧拉图,否则不是。

未1a原因:

1,有一段时间没写并查集了,这次并查集,并的时候也写错!SB啊!

2. 特殊情况,0个点的时候输出可能

#include<iostream>  //594ms
#include<cstring>
#include<string>
#include<cstdio>
using namespace std;
int degree[510001];
int trie[1010001][27];int numtrie=0;
int numv=0;
int fa[510001];
int find(int x)
{
if(x!=fa[x]) fa[x]=find(fa[x]);
return fa[x];
}
int insert_getnum(string s) //字典树,本质hash判重,是否同一个颜色,并返回该结点
{
int u=0;
int len=s.size();
for(int i=0;i<len;i++)
{
if(trie[u][s[i]-'a']==0)
trie[u][s[i]-'a']=++numtrie;
u=trie[u][s[i]-'a'];
}
if(trie[u][26]==0)
trie[u][26]=++numv;
return trie[u][26];
}
bool is_together() //是否连通
{
int count=0;
for(int i=1;i<=numv;i++)
{
if(i==fa[i])count++;
if(count>1)break;
}
if(count>1)return 0;
return 1;
}
bool is_euler() //有欧拉?
{
int count=0;
for(int i=1;i<=numv;i++)
{
if(degree[i]&1)count++;
}
if(count==0||count==2)return 1;
else return 0;
}
int main()
{
char s1[12],s2[12];
for(int i=1;i<500001;i++)
fa[i]=i;
while(scanf("%s %s",s1,s2)!=EOF)
{
string s=s1;
string ss=s2;
int x=insert_getnum(s);
int y=insert_getnum(ss);
degree[x]++;
degree[y]++;
int xx=find(x); //因为并查集在这里跪了俩次了!
int yy=find(y);
if(xx!=yy) //这样合并啊!
fa[yy]=xx;
}
if(numv==0||is_euler()&&is_together())printf("Possible\n");
else printf("Impossible\n");
return 0;
}

最新文章

  1. LINQ之延迟加载及其原理
  2. python 中的 try/except/else/finally语句
  3. JSP弹出窗口和模式对话框
  4. HTML 学习笔记(表格)
  5. PHP图形图像处理之初识GD库
  6. Android:使用ViewPager实现左右滑动切换图片(图上有点点)
  7. 【HDOJ】4089 Activation
  8. java.sql.SQLException: Invalid parameter object type. Expected &#39;java.util.Map&#39; but found &#39;java.lang.String 转载
  9. css重点
  10. openvpn 连接无法上网
  11. java基础之&amp;amp; 和 &amp;amp;&amp;amp; 的差别
  12. ARC注意的泄漏问题
  13. 1026: [SCOI2009]windy数
  14. HTML学习笔记 基础表格案例 第二节 (原创) 参考使用表
  15. spring装配Bean过程
  16. Appium移动自动化测试之—基于java的iOS环境搭建
  17. C语言之free函数及野指针
  18. 限流redis+lua
  19. git 的常用命令(未完待补充)
  20. office 2016 破解教程

热门文章

  1. MAC 安装汇编编译工具 NASM
  2. 数据库_5_MySQL数据库介绍
  3. CPP-基础:C++拷贝构造函数详解
  4. java socket domain name 使用域名.
  5. CentOS7服务器上部署Oracle客户端
  6. 【Python学习之二】装饰器
  7. jenkins学习笔记(一)
  8. DELL R730 服务器拷贝大文件
  9. 在 shell中, 我們可用 $0, $1, $2, $3 ... 這樣的变量分別提取命令行中变量
  10. gitlab之gitlab-ci自动部署