设s[x][i]表示从根到x的异或和在第i位上的值(0/1),(a,b,i)表示a到b的异或和在第i位上的值
那么就有(a,b,i)=(s[a][i]^s[b][i]^s[lca][i]^s[lca][i])=(s[a][i]^s[b][i])
也就是说,能搞出来s[a][i]和s[b][i]的相同或不同关系
用一个并查集,把每个点拆成x和x',分别表示与x相同和与x不同
若中间出现了矛盾,就是Impossible
若最后同一侧的连通块数>2,就说明答案不唯一
然后对于每一条树上的边(a,b),如果a和b相同,这个边在第i位上就是0,否则就是1

 #include<bits/stdc++.h>
#define pa pair<int,int>
#define CLR(a,x) memset(a,x,sizeof(a))
using namespace std;
typedef long long ll;
const int maxn=1e5+,maxm=2e5+; inline ll rd(){
ll x=;char c=getchar();int neg=;
while(c<''||c>''){if(c=='-') neg=-;c=getchar();}
while(c>=''&&c<='') x=x*+c-'',c=getchar();
return x*neg;
} int eg[maxn][],id[maxn][][],pct;
int fa[maxn*],N,M;
int flag[maxn*]; inline int getf(int x){return x==fa[x]?x:fa[x]=getf(fa[x]);} inline void add(int a,int b){
int x=getf(a),y=getf(b);
if(x!=y) fa[x]=y;
} int main(){
//freopen("","r",stdin);
int i,j,k;
for(int T=rd();T;T--){
N=rd(),M=rd();
bool ans=;pct=;
for(i=;i<=N;i++){
for(j=;j<=;j++)
id[i][j][]=++pct,fa[pct]=pct,id[i][j][]=++pct,fa[pct]=pct;
}
for(i=;i<N;i++)
eg[i][]=rd(),eg[i][]=rd();
for(i=;i<=M;i++){
int a=rd(),b=rd(),w=rd();
for(j=;j<=;j++){
if((w>>(j-))&){
if(getf(id[a][j][])==getf(id[b][j][])) ans=;
add(id[a][j][],id[b][j][]);
add(id[a][j][],id[b][j][]);
}else{
if(getf(id[a][j][])==getf(id[b][j][])) ans=;
add(id[a][j][],id[b][j][]);
add(id[a][j][],id[b][j][]);
}
}
}
if(!ans){
printf("Impossible\n");
continue;
}
CLR(flag,);
for(i=;i<=;i++){
int cnt=;
for(j=;j<=N;j++){
if(!flag[getf(id[j][i][])])
flag[getf(id[j][i][])]=++cnt;
}
if(cnt>){ans=;break;}
}
if(!ans){
printf("No\n");
continue;
}
int mi=1e9,ma=;
for(i=;i<N;i++){
int a=eg[i][],b=eg[i][],x=;
for(j=;j<=;j++){
if(getf(id[a][j][])!=getf(id[b][j][]))
x|=<<(j-);
}
mi=min(mi,x),ma=max(ma,x);
}
printf("%d %d\n",mi,ma);
} return ;
}

loj6157 A ^ BProblem (并查集)的更多相关文章

  1. loj6157 A^B Problem (并查集)

    题目: https://loj.ac/problem/6157 分析: 这种树上异或,一般是采用分位考虑,但是这题即使分位,也会发现非常不好处理 这里考虑维护一个点到其根的路径的异或值 用并查集去检测 ...

  2. BZOJ 4199: [Noi2015]品酒大会 [后缀数组 带权并查集]

    4199: [Noi2015]品酒大会 UOJ:http://uoj.ac/problem/131 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战两个环节,分别向优胜者颁发“首席品 ...

  3. 关押罪犯 and 食物链(并查集)

    题目描述 S 城现有两座监狱,一共关押着N 名罪犯,编号分别为1~N.他们之间的关系自然也极不和谐.很多罪犯之间甚至积怨已久,如果客观条件具备则随时可能爆发冲突.我们用"怨气值"( ...

  4. 图的生成树(森林)(克鲁斯卡尔Kruskal算法和普里姆Prim算法)、以及并查集的使用

    图的连通性问题:无向图的连通分量和生成树,所有顶点均由边连接在一起,但不存在回路的图. 设图 G=(V, E) 是个连通图,当从图任一顶点出发遍历图G 时,将边集 E(G) 分成两个集合 T(G) 和 ...

  5. bzoj1854--并查集

    这题有一种神奇的并查集做法. 将每种属性作为一个点,每种装备作为一条边,则可以得到如下结论: 1.如果一个有n个点的连通块有n-1条边,则我们可以满足这个连通块的n-1个点. 2.如果一个有n个点的连 ...

  6. [bzoj3673][可持久化并查集 by zky] (rope(可持久化数组)+并查集=可持久化并查集)

    Description n个集合 m个操作 操作: 1 a b 合并a,b所在集合 2 k 回到第k次操作之后的状态(查询算作操作) 3 a b 询问a,b是否属于同一集合,是则输出1否则输出0 0& ...

  7. [bzoj3123][sdoi2013森林] (树上主席树+lca+并查集启发式合并+暴力重构森林)

    Description Input 第一行包含一个正整数testcase,表示当前测试数据的测试点编号.保证1≤testcase≤20. 第二行包含三个整数N,M,T,分别表示节点数.初始边数.操作数 ...

  8. 【BZOJ-3673&3674】可持久化并查集 可持久化线段树 + 并查集

    3673: 可持久化并查集 by zky Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 1878  Solved: 846[Submit][Status ...

  9. Codeforces 731C Socks 并查集

    题目:http://codeforces.com/contest/731/problem/C 思路:并查集处理出哪几堆袜子是同一颜色的,对于每堆袜子求出出现最多颜色的次数,用这堆袜子的数目减去该值即为 ...

随机推荐

  1. #Leetcode# 836. Rectangle Overlap

    https://leetcode.com/problems/rectangle-overlap/ A rectangle is represented as a list [x1, y1, x2, y ...

  2. Linux 典型应用之缓存服务

    memcached 安装和简单使用 yum install memcached 启动 -d 表示以守护进程的方式启动 memcached -d 安装telnet 它可以检测某个端口是否是通的,可以发送 ...

  3. LINUX操作系统(centos6.9)安装与配置

    LINUX操作系统(centos6.9)安装与配置_百度经验 https://jingyan.baidu.com/article/acf728fd6bdba1f8e510a3f7.html cento ...

  4. 将Myeclipse项目改成Eclipse项目

    由于项目需求,需要将原来Myeclipse项目转移到Eclipse中去.搞了半天才搞出来,分享给大家,希望对大家有用. 首先导入一个从Myeclipse导出的项目 然后无法进行tomcat发布. 但是 ...

  5. springIOC源码分析(BeanFactroy)

    启动spring容器加载bean的方式有两种:最基本的容器BeanFactory和高级容器ApplicationContext.这篇文章介绍使用BeanFactory加载bean时的整个过程,当然,A ...

  6. spring初始化bean时执行某些方法完成特定的初始化操作

    在项目中经常会在容器启动时,完成特定的初始化操作,如资源文件的加载等. 一 实现的方式有三种: 1.使用@PostConstruct注解,该注解作用于void方法上 2.在配置文件中配置init-me ...

  7. 简单易懂的softmax交叉熵损失函数求导

    参考: https://blog.csdn.net/qian99/article/details/78046329

  8. Spark join连接

    内链接

  9. mvn clean compile package install deploy

    (1) package 目的是打包,在pom中,如果是jar就会打包成jar,如果是war就会打包成war 在pom.xml中: <modelVersion></modelVersi ...

  10. Bootstrap之登陆页面范例

    代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta ...