\(\mathcal{Description}\)

  Link.

  给定 \(n\) 个点 \(m\) 条边的连通无向图 \(G\),边有边权。其中 \(u,v\) 的距离 \(d(u,v)\) 定义为 \(u\) 到 \(v\) 的最大异或路径。还有 \(q\) 次询问,每次给出 \(l,r\),求 \(\bigoplus_{l\le i<j\le r}d(i,j)\)。

  \(n,m,q\le10^5\),边权 \(w<2^{30}\)。

\(\mathcal{Solution}\)

  首先必然套用这个经典永流传的结论:设所有环的异或和构成空间 \(V\),\(d'(u,v)\) 为 \(u\) 到 \(v\) 的任意一条路径的异或和,则 \(d(u,v)=\max\{d'(u,v)\oplus x\mid x\in V\}\)。

  记变换 \(F_V:x\rightarrow \max\{x\oplus v\mid v\in V\}\),由于它不具有线性性,我们拆开 \(d(u,v)\) 的 \(\max\) 进行优化就显得困难。不过,考查与之类似的另一个变换 \(G_V:x\rightarrow\min\{x\oplus v\mid v\in V\}\),能够证明 \(G_V\) 是线性变换,且会得到一个炫酷的结论:\(F_V(x)=G_V(x)\oplus\max\{v\mid v\in V\}\)。

证明

  把 $x$ 等元素视为 $U=\{0,1\}^k$ 下的向量。设 $\boldsymbol x=\begin{pmatrix}x_0& x_1&\cdots& x_{k-1}\end{pmatrix}$,取 $U$ 的子空间 $V$ 的线性基 $\mathcal B$,令
$$
\mathcal B=\begin{pmatrix}\boldsymbol b_0\\ \boldsymbol b_1\\ \vdots \\ \boldsymbol b_{k-1}\end{pmatrix},
$$
其中 $\boldsymbol b_i=\begin{pmatrix} b_{i,0} & b_{i,1}&\cdots& b_{i,k-1} \end{pmatrix}$,且有 $\forall j\lt i,b_{i,j}=0$。此时考虑 $\boldsymbol x\mathcal B^T$ 的意义:若 $\boldsymbol x$ 某一分量为 $1$,则加上(即异或上)线性基中的对应向量,很显然就是在线性基中构造 $\min\{x\oplus v\mid v\in V\}$ 的方式,所以 $G_V$ 是一个线性变换。 $\square$

  “炫酷结论”就不证了,自证不难。

  回到题目,处理一下式子:

\[\begin{aligned}\bigoplus_{l\le i<j\le r}d(i,j) &= \bigoplus_{l\le i<j\le r}d'(i,j)\oplus G_V(d'(i,j))\oplus \max\{v\mid v\in V\}\\&= \left(\binom{r-l+1}{2}\otimes\max\{v\mid v\in V\}\right)\oplus G_V\left( \bigoplus_{l\le i<j\le r}d'(i,j) \right).\end{aligned}
\]

抵消掉大量重复异或之后直接计算即可。复杂度 \(\mathcal O(n+(m+q)\log w)\)。

\(\mathcal{Code}\)

/*~Rainybunny*/

#include <bits/stdc++.h>

#define rep( i, l, r ) for ( int i = l, rep##i = r; i <= rep##i; ++i )
#define per( i, r, l ) for ( int i = r, per##i = l; i >= per##i; --i ) const int MAXN = 1e5;
int n, m, q, ecnt, head[MAXN + 5], dis[MAXN + 5];
bool vis[MAXN + 5]; struct Edge { int to, val, nxt; } graph[MAXN * 2 + 5]; struct XorLinearBasic {
static const int W = 30;
int bas[W]; inline void insert( int v ) {
per ( i, W, 0 ) if ( v >> i & 1 ) {
if ( !bas[i] ) return void( bas[i] = v );
v ^= bas[i];
}
} inline int ask( int v, const bool tar ) {
per ( i, W, 0 ) if ( ( v >> i & 1 ) != tar ) v ^= bas[i];
return v;
}
} xlb; inline void link( const int u, const int v, const int w ) {
graph[++ecnt] = { v, w, head[u] }, head[u] = ecnt;
graph[++ecnt] = { u, w, head[v] }, head[v] = ecnt;
} inline void getCir( const int u ) {
vis[u] = true;
for ( int i = head[u], v; i; i = graph[i].nxt ) {
if ( vis[v = graph[i].to] ) {
xlb.insert( dis[u] ^ dis[v] ^ graph[i].val );
} else {
dis[v] = dis[u] ^ graph[i].val, getCir( v );
}
}
} int main() {
std::ios::sync_with_stdio( false ), std::cin.tie( 0 ); std::cin >> n >> m >> q;
rep ( i, 1, m ) {
int u, v, w; std::cin >> u >> v >> w;
link( u, v, w );
} getCir( 1 );
rep ( i, 1, n ) dis[i] ^= dis[i - 1]; for ( int l, r; q--; ) {
std::cin >> l >> r;
std::cout << xlb.ask( ( r - l ) & 1 ? dis[r] ^ dis[l - 1] : 0,
( r - l + 1ll ) * ( r - l ) >> 1 & 1 ) << '\n';
}
return 0;
}

Solution -「Gym 102956F」Find the XOR的更多相关文章

  1. Solution -「Gym 102956F」Border Similarity Undertaking

    \(\mathcal{Description}\)   Link.   给定一张 \(n\times m\) 的表格,每个格子上写有一个小写字母.求其中长宽至少为 \(2\),且边界格子上字母相同的矩 ...

  2. Solution -「Gym 102979E」Expected Distance

    \(\mathcal{Description}\)   Link.   用给定的 \(\{a_{n-1}\},\{c_n\}\) 生成一棵含有 \(n\) 个点的树,其中 \(u\) 连向 \([1, ...

  3. Solution -「Gym 102979L」 Lights On The Road

    \(\mathcal{Description}\)   Link.   给定序列 \(\{w_n\}\),选择 \(i\) 位置的代价为 \(w_i\),要求每个位置要不被选择,要不左右两个位置至少被 ...

  4. Solution -「Gym 102956B」Beautiful Sequence Unraveling

    \(\mathcal{Description}\)   Link.   求长度为 \(n\),值域为 \([1,m]\) 的整数序列 \(\lang a_n\rang\) 的个数,满足 \(\not\ ...

  5. Solution -「Gym 102956A」Belarusian State University

    \(\mathcal{Description}\)   Link.   给定两个不超过 \(2^n-1\) 次的多项式 \(A,B\),对于第 \(i\in[0,n)\) 个二进制位,定义任意一个二元 ...

  6. Solution -「Gym 102798I」Sean the Cuber

    \(\mathcal{Description}\)   Link.   给定两个可还原的二阶魔方,求从其中一个状态拧到另一个状态的最小步数.   数据组数 \(T\le2.5\times10^5\). ...

  7. Solution -「Gym 102798K」Tree Tweaking

    \(\mathcal{Description}\)   Link.   给定排列 \(\{p_n\}\),求任意重排 \(p_{l..r}\) 的元素后,将 \(\{p_n\}\) 依次插入二叉搜索树 ...

  8. Solution -「Gym 102798E」So Many Possibilities...

    \(\mathcal{Description}\)   Link.   给定非负整数序列 \(\{a_n\}\) 和 \(m\),每次随机在 \(\{a\}\) 中取一个非零的 \(a_i\)(保证存 ...

  9. Solution -「Gym 102759I」Query On A Tree 17

    \(\mathcal{Description}\)   Link.   给定一棵含 \(n\) 个结点的树,结点 \(1\) 为根,点 \(u\) 初始有点权 \(a_u=0\),维护 \(q\) 次 ...

随机推荐

  1. 怎样从 bat 批处理文件调用 PowerShell 脚本

    https://stackoverflow.com/questions/19335004/how-to-run-a-powershell-script-from-a-batch-file https: ...

  2. react中使用react-transition-group(CSSTransition)

    https://blog.csdn.net/sophie_u/article/details/80093876

  3. win10中查看开关机时间及查看admin的RID的方法

    原文链接: https://www.toutiao.com/i6772133439593251339/ 打开系统的注册表 键盘输入win+r组合键出现运行窗口命令 输入regedit 按回车键,进入注 ...

  4. IK 分词器

    目录 IK 分词器-介绍 IK 分词器-安装 环境准备:Maven 安装 IK 分词器 IK 分词器-使用 IK 分词器-介绍 现有问题:ES 默认对中文分词并不友好,实际上是把中文进行了每个字的分词 ...

  5. 移动端调试 - UC浏览器开发者版 - WIFI

    Chrome  功能特性 支持PC或Pad设备,实时调试手机网页 DOM.CSS.JS调试 多功能面板满足多种调试需求 1   准备工作 保证手机与PC处于同一个无线网段. 下载Android平台的U ...

  6. 图形测试分析毫无头绪?HarmonyOS图形栈测试技术帮你解决

    作者:huangran,图形图像技术专家 应用开发以后无法知道性能瓶颈的根因是什么?滑动卡顿.白块产生的原因是什么?代码写完之后,不知道如何优化让它表现地更好-- 我们发现,如今测试人员的需求已经不只 ...

  7. 嫌Excel VBA执行速度慢,这些建议你一定要看

    Excel是办公利器,这无需多言.尤其在办公室,Excel用的熟练与否,会的Excel知识点多不多,很大程度上决定了你工作是否高效,能否按时打卡下班.可我们也时常听到这样的吐槽:Excel好是好,可就 ...

  8. [STM32F10x] 标准库初始化问题

    硬件:STM32F103C8T6 平台:ARM-MDK V5.11 STM32F系列提供的标准库都是通过结构体来初始化的.比如,以下是GPIO初始化的一个示例代码: GPIO_InitTypeDef ...

  9. 1月29日 体温APP开发记录

    1.阅读构建之法 现代软件工程(第三版) 2.观看Android开发视频教程最新版 Android Studio开发 3.高德地图API下载获取key  

  10. vue中$nextTick的使用

    转载 https://www.jb51.net/article/154823.htm  ,写的通俗易懂 在这里我有一个疑问,因为在vue中mounted里面执行后,dom节点是挂载上去了的,所以视图上 ...