【BZOJ】2115: [Wc2011] Xor
http://www.lydsy.com/JudgeOnline/problem.php?id=2115
题意:给出一个n个点m条边的无向连通边加权图,求1~n的某条路径使得异或值最大(可以重复点可以重复边)(n<=50000, m<=100000)
#include <bits/stdc++.h>
using namespace std;
const int N=50005, M=100015;
typedef long long ll;
struct E { int next, to; ll w; }e[M<<1];
int cnt, ihead[N], tot, n, m;
ll d[N], q[M*10], a[65];
void add(int u, int v, ll c) {
e[++cnt]=(E){ihead[u], v, c}; ihead[u]=cnt;
e[++cnt]=(E){ihead[v], u, c}; ihead[v]=cnt;
}
bool vis[N];
void dfs(int x) {
vis[x]=1;
for(int i=ihead[x]; i; i=e[i].next)
if(!vis[e[i].to]) d[e[i].to]=d[x]^e[i].w, dfs(e[i].to);
else q[++tot]=d[e[i].to]^d[x]^e[i].w;
}
int main() {
scanf("%d%d", &n, &m);
for(int i=0; i<m; ++i) { int x, y; ll w; scanf("%d%d%lld", &x, &y, &w); add(x, y, w); }
dfs(1);
for(int i=1; i<=tot; ++i)
for(int j=60; j>=0; --j) if((q[i]>>j)&1) {
if(!a[j]) { a[j]=q[i]; break; }
else q[i]^=a[j];
}
ll ans=d[n];
for(int j=60; j>=0; --j) if(!((ans>>j)&1)) ans^=a[j];
printf("%lld\n", ans);
return 0;
}
//PS:一下都是在本人什么都不懂的情况下乱写的,大家请有选择性的查看= =.....(体现了sb iwtwiioi是多么的弱(我就懒得删了..反正大概就是找出一组线性无关的元素,然后就能组成整个向量空间了= =然后就行了..
好题不解释..
首先去学习了一下线性基。这里说的线性基在这里具体是指某个向量数组在xor操作下形成的封闭集合中的线性无关量。我们求出这些基后就能很简单的贪心求出答案了。
然后再学习了一个特殊的性质= =在生成树上的非树边所形成的环在xor的情况下能表示出所有环的xor值(这个yy了好久证明不出,只能手工验证正确性..大概就是每一个非树边都存在有且一个所求出的环中,然后用一些环进行xor抵消掉一些树边然后就形成了新的环)
基的个数上界就是$O(log(n))$
然后我们只需要通过高斯消元求出每一位都独立的一个元素那么可以当成一个基,最后一定会出现一组基...大小为$O(log(n)), n为向量的大小$,也就是说,某个基的最高位存在而其它基都不存在这个位。
由于xor操作的封闭性,我们只需要像高斯消元一样消去某一位上其它元素的值即可。
回到本题...
由于一条1~n的路径可以由任意一条1~n的简单路径加上任意个环组成。(从简单路径中进入环的路径和出环的路径(同一条)xor抵消)
由之前所说,非树边的环可以线性组成所有环的xor值,所以我们直接搞就行了...
(ps:诶呀诶呀一定要强拉到基吗...最好理解的就是,我要贪心,所以我要变成一些数使得最高位只有一个数有其他数没有,而且这些数能线性组合成之前的向量所能组成的所有数。就行了你们说是不是,sb iwtwiioi还扯了一大版自己都不懂的东西
【BZOJ】2115: [Wc2011] Xor的更多相关文章
- 【BZOJ】2337: [HNOI2011]XOR和路径 期望+高斯消元
[题意]给定n个点m条边的带边权无向连通图(有重边和自环),在每个点随机向周围走一步,求1到n的期望路径异或值.n<=100,wi<=10^9. [算法]期望+高斯消元 [题解]首先异或不 ...
- 【题解】 bzoj2115: [Wc2011] Xor (线性基+dfs)
bzoj2115,戳我戳我 Solution: 看得题解(逃,我太菜了,想不出这种做法 那么丢个链接 Attention: 板子别写错了 又写错了这次 \(long long\)是左移63位,多了会溢 ...
- BZOJ 2115: [Wc2011] Xor
2115: [Wc2011] Xor Time Limit: 10 Sec Memory Limit: 259 MB Submit: 2794 Solved: 1184 [Submit][Stat ...
- bzoj 2115: [Wc2011] Xor xor高斯消元
2115: [Wc2011] Xor Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 797 Solved: 375[Submit][Status] ...
- BZOJ 2115: [Wc2011] Xor DFS + 线性基
2115: [Wc2011] Xor Time Limit: 10 Sec Memory Limit: 259 MB Description Input 第一行包含两个整数N和 M, 表示该无向图中 ...
- 【BZOJ】3052: [wc2013]糖果公园
http://www.lydsy.com/JudgeOnline/problem.php?id=3052 题意:n个带颜色的点(m种),q次询问,每次询问x到y的路径上sum{w[次数]*v[颜色]} ...
- 【BZOJ】3319: 黑白树
http://www.lydsy.com/JudgeOnline/problem.php?id=3319 题意:给一棵n节点的树(n<=1e6),m个操作(m<=1e6),每次操作有两种: ...
- 【BZOJ】3319: 黑白树(并查集+特殊的技巧/-树链剖分+线段树)
http://www.lydsy.com/JudgeOnline/problem.php?id=3319 以为是模板题就复习了下hld............................. 然后n ...
- 【BZOJ】1013: [JSOI2008]球形空间产生器sphere
[BZOJ]1013: [JSOI2008]球形空间产生器sphere 题意:给n+1个n维的点的坐标,要你求出一个到这n+1个点距离相等的点的坐标: 思路:高斯消元即第i个点和第i+1个点处理出一个 ...
随机推荐
- Bitmap在Java中的实现和应用
>>40亿数据排序问题 给定一个最多包含40亿个随机排列的32位整数的顺序文件,找出一个不在文件中的32位整数(在文件中至少缺失这样一个数——为什么?).在具有足够内存的情况下,如何解决该 ...
- Bootstrap简介
接下来的一段时间,想研究一下现有的网页框架,第一个不容错过的就是Bootstrap,Bootstrap 是一个用于快速开发 Web 应用程序和网站的前端框架.Bootstrap 是基于 HTML.CS ...
- Mysql中文乱码问题完美解决方案
drop database`netctoss_demo` ;CREATE DATABASE `netctoss_demo` CHARACTER SET 'utf8' COLLATE 'utf8_gen ...
- jquery 仿百度搜索下拉框的插件
转载地址:http://www.open-open.com/lib/view/open1420624048437.html 今天写了个下拉插件分享出来 效果: , 可以搜素,也可以使用上下键选择匹配出 ...
- win8.1/win10 UEFI + GPT 安装(测试机型:华硕S56CM)
本教程简要介绍在UEFI 启动模式下在GPT分区表中,最简单的方法安装 Windows 10 x64 位系统.(并非傻瓜教程,安装者总要有一定的经验基础)下面先简单介绍一下UEFI和GTP. UEFI ...
- 信号量进程同步,王明学learn
信号量进程同步 一组并发进程进行互相合作.互相等待,使得各进程按一定的顺序执行的过程称为进程间的同步. 信号量在进程同步时初始值为:0 信号量在进程互斥时初始值为:大于0的 本章节主要使用信号量,使的 ...
- matlab练习程序(碎片)
这个算法是对photoshop中滤镜->像素化->碎片这个功能的学习. PS这个功能好像不带参数,不过我这里有滤波半径r可以进行控制. 因为我是看效果猜算法的,效果肯定有所区别. 我的想法 ...
- Apache Tomcat配置
- 用户视角 vs 系统视角 看性能
如何评价性能的优劣: 用户视角 vs. 系统视角 对于最终用户(End-User)来说,评价系统的性能好坏只有一个字——“快”.最终用户并不需要关心系统当前的状态——即使系统这时正在处理着成千上万的请 ...
- LoadRunner如何监控Tomcat性能
使用LoadRunner做性能测试,一般的直觉是LR只能完成脚本录制和编写模拟用户的请求行为,但是在某些情况下,要监控一些中间件或web服务器的性能时,就不能通过录制脚本来完成了,那么就需要手工来编写 ...