【题目描述】
BZOJ2115XOR——线性基

【题目分析】
这道题看完以后很懵逼,人家要是走的很复杂呢?各种绕来绕去怎么办?
首先我们应该注意到一个很明显的道理:重复的路径会和自身抵消,所以我们大可以随便跑,只要再跑回来就对答案没有影响。因此,有影响的只有选择的路径和经过的环,因为环是可以回到已经经过的点而不抵消的。而且只要我们愿意我们可以去任何一个环(假如环有一个起点x,我们有一条从1到n的路径,可能这个环和路径没有交点,但是我们可以从某一点跑到x然后经过这个环再跑回来,这样我们就经过这个环了)
我们算法的策略是:任选一个从1到n路径的xor和作为初始值然后再以各个环作为线性基求最大值
可能你会疑惑,任意选一个路径真的没有问题吗?假如从1到n只有这一条路径我们显然必须选,可是有很多路径的时候他们就会构成环,而我们已经将各种环都加入线性基了,通过选的这条路和其他环的异或我们就能得到其他路径(相当于可以被抵消)
另外,面向板子编程真的好爽,以后一定要认认真真的整理板子。这个线性基的板子就挺好用
【参考博客】
BZOJ2115 [Wc2011] Xor
【AC代码】

#include<cstdio>
#include<cstring>
#include<cmath>
#include<climits>
#include<cstdlib>
#include<algorithm>
#include<queue>
#include<vector>
#include<set>using namespace std;typedef long long ll;const int MAXN=50005;
const int MAXM=100005;
struct node
{int from,to;ll weight;
}edge[MAXM<<1];
int head[MAXM<<1],nxt[MAXM<<1];
int tot=0;
int n,m;
ll dis[MAXN];
bool vis[MAXN];struct L_B
{ll b[65],p[65];int cnt,flag;L_B(){memset(p,0,sizeof(p));memset(b,0,sizeof(b));cnt=flag=0;}inline bool insert(ll x){for(int i=62;i>=0;--i)if(x&(1ll<<i)){if(b[i])x^=b[i];else{b[i]=x;return true;}}flag=1;return false;}ll get_max(){ll ret = 0;for(int i=62;i>=0;--i)if((ret^b[i])>ret)ret^=b[i];return ret;}ll get_max(ll initval){ll ret = initval;for(int i=62;i>=0;--i)if((ret^b[i])>ret)ret^=b[i];return ret;}ll get_min(){if(flag)return 0;for(int i=0;i<=62;++i)if(b[i])return b[i];return 0;}inline void rebuild(){for(int i = 1;i <= 62;++i)if(b[i])for(int j=0;j<i;++j)if(b[i]&(1ll<<j))b[i]^=b[j];for(int i=0;i<=62;++i)if(b[i])p[cnt++]=b[i];}ll kth(ll k){if(flag)--k;if(k==0)return 0;ll ret = 0;if(k>=(1ll<<cnt))return -1;for(int i=0;i<=cnt-1;++i)if(k&(1ll<<i))ret^=p[i];return ret;}
};
L_B lis;inline int getint(){int w=0,q=0;char c=getchar();while((c<'0'||c>'9')&&c!='-')c=getchar();if(c=='-')q=1,c=getchar();while (c>='0' && c<='9') w=w*10+c-'0', c=getchar(); return q ? -w : w;}
inline ll getlong(){ll w=0,q=0;char c=getchar();while((c<'0' || c>'9')&&c!='-')c=getchar();if(c=='-') q=1,c=getchar();while (c>='0' && c<='9') w=w*10+c-'0', c=getchar(); return q ? -w : w;}void AddEdge(int u,int v,ll w)
{tot++;edge[tot].from=u; edge[tot].to=v; edge[tot].weight=w;nxt[tot]=head[u]; head[u]=tot;
}void dfs(int x)
{int v;vis[x]=true;for(int i=head[x];i;i=nxt[i]){v=edge[i].to;if(!vis[v]){dis[v]=dis[x]^edge[i].weight;dfs(v);}else{lis.insert(dis[x]^dis[v]^edge[i].weight);}}
}int main()
{int u,v; ll w;n=getint(); m=getint();for(int i=0;i<m;i++){u=getint(); v=getint(); w=getlong(); AddEdge(u,v,w); AddEdge(v,u,w);}dfs(1);printf("%lld",lis.get_max(dis[n]));return 0;
}

BZOJ2115XOR——线性基相关推荐

  1. 【线段树分治 线性基】luoguP3733 [HAOI2017]八纵八横

    不知道为什么bzoj没有HAOI2017 题目描述 Anihc国有n个城市,这n个城市从1~n编号,1号城市为首都.城市间初始时有m条高速公路,每条高速公路都有一个非负整数的经济影响因子,每条高速公路 ...

  2. BZOJ4568: [Scoi2016]幸运数字(线性基 倍增)

    题意 题目链接 Sol 线性基是可以合并的 倍增维护一下 然后就做完了?? 喵喵喵? // luogu-judger-enable-o2 #include<bits/stdc++.h> # ...

  3. HDU3949(线性基算法模版)

    题意:给出N个数,再给出q次查询,每一次的查询在N个数中的值进行异或后第k小的值是多少! 这个线性基我也今天刚学,也只是在套模版,有些地方感觉有点难理解! #include<iostream&g ...

  4. 线性基+树上倍增 ---- BZOJ4568[线性基+树上倍增]

    题目链接 题目大意:就是给你一棵树,每个树上的节点都有一个权值,现在给你一个询问u和v问你这个路径上面挑任意几个数进行xor运算,问你xor最大值是多少 解题思路:对于每个点我们可以维护它向根节点上面 ...

  5. Luogu P5556 圣剑护符(线性基,树链剖分,线段树)

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 Problem 小L 和 小K 面前的圣剑由 nnn 块护符组成,分别编号为 1,2,-,n1,2,\ ...

  6. HDU3949 XOR (线性基、查找第k小值)

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 我们用高斯消元求出的a1,a2,-,ana_1,a_2, \dots,a_na1​,a2​,-,an​ ...

  7. 2017年ICPC西安邀请赛A、XOR(线段树套线性基 + 思维)

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 题目传送门 Problem 给你 nnn 和 nnn 个整数的数组 aaa,以及kkk和qqq,有 q ...

  8. CF724G Xor-matic Number of the Graph(线性基+组合数)

    题目描述 给你一个无向图,有n个顶点和m条边,每条边上都有一个非负权值. 我们称一个三元组(u,v,s)是有趣的,当且仅当对于u,v,有一条从u到v的路径(可以经过相同的点和边多次),其路径上的权值异 ...

  9. [洛谷3812]【模板】线性基

    题目大意: 给你n个数,求这些数能异或出的数的最大值. 思路: 线性基模板. b中的数满足对于每个b[i],最高位在第i位. 构造方法就是对于每个数字,从高到低枚举每一个1,如果这一位对应的b[i]还 ...

最新文章

  1. 李开复:AI巨头是有史以来最难以打破的垄断
  2. 第四条:通过私有构造器强化不可实例化的能力
  3. Python学习之路:NumPy初识
  4. listen()与accept()函数的区别
  5. Sql Server 分区演练
  6. 【概率与期望】[UVA11021]Tribles
  7. java的队列实现方法_Java实现队列的三种方法集合
  8. Python 基础总结 6 张图 带你学习Python
  9. 04:数组逆序重放【一维数组】
  10. 2021-2025年中国制药废物处理与管理行业市场供需与战略研究报告
  11. JSON格式解析和libjson使用简介-转
  12. deepsort报错 No module named ‘sklearn.utils.linear_assignment_‘ 问题解决
  13. 下了高铁直接上地铁,多方便
  14. hⅰgh怎么读音发音英语_英语发音规则---gh
  15. 全国各省市区县数据整理
  16. Android Studio中的 Image Asset Studio(图标生成工具)
  17. Android架构之高可用移动网络连接
  18. MySQL参数 之 innodb_buffer_pool_size
  19. cad在线转低版本_CAD这些技巧你还不会怎么当大神
  20. ati hd 6470m驱动

热门文章

  1. Linux 文件属性
  2. 201571030316/201571030314 《小学四则运算练习软件需求说明》结对项目报告
  3. JavaWeb基础(jsp初识)
  4. const 和readonly
  5. 142. Linked List Cycle II
  6. vs 2012,vs 2013问题系列
  7. 实现sessionfilter_session应用--采用filter和session实现简单用户权限控制
  8. finditerable 转list_java – 通过拆分和运行将ListenableFuture转换为Iterable
  9. linux ip地址漂移,Linux 实现高可用性(HA) —之ip 漂移方法(vrrp)
  10. php实现第三方邮箱登录_PHP实现用户异地登录提醒功能的方法