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的更多相关文章

  1. 【BZOJ】2337: [HNOI2011]XOR和路径 期望+高斯消元

    [题意]给定n个点m条边的带边权无向连通图(有重边和自环),在每个点随机向周围走一步,求1到n的期望路径异或值.n<=100,wi<=10^9. [算法]期望+高斯消元 [题解]首先异或不 ...

  2. 【题解】 bzoj2115: [Wc2011] Xor (线性基+dfs)

    bzoj2115,戳我戳我 Solution: 看得题解(逃,我太菜了,想不出这种做法 那么丢个链接 Attention: 板子别写错了 又写错了这次 \(long long\)是左移63位,多了会溢 ...

  3. BZOJ 2115: [Wc2011] Xor

    2115: [Wc2011] Xor Time Limit: 10 Sec  Memory Limit: 259 MB Submit: 2794  Solved: 1184 [Submit][Stat ...

  4. bzoj 2115: [Wc2011] Xor xor高斯消元

    2115: [Wc2011] Xor Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 797  Solved: 375[Submit][Status] ...

  5. BZOJ 2115: [Wc2011] Xor DFS + 线性基

    2115: [Wc2011] Xor Time Limit: 10 Sec  Memory Limit: 259 MB Description Input 第一行包含两个整数N和 M, 表示该无向图中 ...

  6. 【BZOJ】3052: [wc2013]糖果公园

    http://www.lydsy.com/JudgeOnline/problem.php?id=3052 题意:n个带颜色的点(m种),q次询问,每次询问x到y的路径上sum{w[次数]*v[颜色]} ...

  7. 【BZOJ】3319: 黑白树

    http://www.lydsy.com/JudgeOnline/problem.php?id=3319 题意:给一棵n节点的树(n<=1e6),m个操作(m<=1e6),每次操作有两种: ...

  8. 【BZOJ】3319: 黑白树(并查集+特殊的技巧/-树链剖分+线段树)

    http://www.lydsy.com/JudgeOnline/problem.php?id=3319 以为是模板题就复习了下hld............................. 然后n ...

  9. 【BZOJ】1013: [JSOI2008]球形空间产生器sphere

    [BZOJ]1013: [JSOI2008]球形空间产生器sphere 题意:给n+1个n维的点的坐标,要你求出一个到这n+1个点距离相等的点的坐标: 思路:高斯消元即第i个点和第i+1个点处理出一个 ...

随机推荐

  1. 重温WCF之数据契约中使用枚举(转载)(十一)

    转载地址:http://www.zhuli8.com/wcf/EnumMember.html 枚举类型的定义总是支持序列化的.当我们定义一个新的枚举时,不必应用DataContract特性,就可以在数 ...

  2. HTML5学习之视频与音频(三)

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  3. Java 8新特性

    Java 8版本最大的改进就是Lambda表达式,其目的是使Java更易于为多核处理器编写代码:其次,新加入的Nashorn引擎也使得Java程序可以和JavaScript代码互操作:再者,新的日期时 ...

  4. JAVA 使用线程的几种方式

    之前放在自己网站上的例子,因为网站关闭,已经找不到了,想用的时候,没有的话又重新翻书是很麻烦的事情.所以重新记录一下,以备将来查看. 第一种,让任务类继承Runable接口,然后将任务类对象放入Thr ...

  5. golang channel basic

    package mainimport ( "fmt" "math/rand" "time")func main() { rand.Seed( ...

  6. 关于ICE

    转自:http://wenda.chinabaike.com/b/38322/2013/1103/614756.html 一.ICE产生的背景 基于信令协议的多媒体传输是一个两段式传输.首先,通过信令 ...

  7. 等号赋值与memcpy的效率问题

    转自:http://www.aiuxian.com/article/p-1309055.html 偶尔看到一个说法,说,小内存的拷贝,使用等号直接赋值比memcpy快得多.结合自己搜集到的资料,整理成 ...

  8. PAT A 1004. Counting Leaves (30)【vector+dfs】

    题目链接:https://www.patest.cn/contests/pat-a-practise/1004 大意:输出按层次输出每层无孩子结点的个数 思路:vector存储结点,dfs遍历 #in ...

  9. LayoutInflater(一)

    相信接触Android久一点的朋友对于LayoutInflater一定不会陌生,都会知道它主要是用于加载布局的.而刚接触Android的朋友可能对LayoutInflater不怎么熟悉,因为加载布局的 ...

  10. 比较和排序(IComparable和IComparer以及它们的泛型实现)

    本文摘要: 1:比较和排序的概念: 2:IComparable和IComparer: 3:IComparable和IComparer的泛型实现IComparable<T>和ICompare ...