CF1615D X(or)-mas Tree

\(Link\)

题意:给定一棵 \(n\) 个点的无根树,每条边有边权。若边权为 \(-1\) 则边权暂定。

然后有 \(m\) 条限制条件,每个条件给出形式为 \((u,v,w)\),表示将 \(u\) 到 \(v\) 最短路径上的边权异或起来,用二进制写出后 \(1\) 的个数的奇偶性

然后构造一种方案,把所有边权确定下来,要求满足所有限制。

(碎碎念:赛时没看到\(1\) 的个数的奇偶性,还以为是憨憨题,然后就GG惹。。。)

\(Solution:\)

首先我们钦定 \(1\) 是根。

设 \(a_i\) 为从 \(1\) 到 \(i\) 的路径上异或起来的值。

于是对于每组 \((u,v,w)\),\(u\) 到 \(v\) 最短路径上的边权异或起来的值就等于 \(a_u \oplus a_v\)。

首先我们能发现一个性质:

\[popcount(x \oplus y) \equiv popcount(x) \oplus popcount(y)\ (\text{mod}\ 2) \]

上一篇:python入门教程10-01 (python语法入门之异常处理)


下一篇:【洛谷】P4887 【模板】莫队二次离线