题意:给定一个图集\((V,E)\),求路径\(1...n\)的最大异或和,其中重复经过的部分也会重复异或

所求既任意一条\(1...n\)的路径的异或和,再异或上任意独立回路的组合的异或和(仔细想想,异或的过程是不是不断抵消并选取更优异或路径的过程?)

因此dfs返向边把环的异或值弄出来丢入线性基中贪心选取即可

顺便转载一下菊苣的独立回路小姿势(电路课似乎讲过但我摸鱼了XD)

首先有个结论:一个无向连通图G中有且仅有M-N+1个独立回路。

独立回路是指任意一个都不能由其他回路构成。

引用一段数学归纳法证明:

“M=N-1时,树,结论成立

设M=K时结论成立,当M=K+1时,任取G中一条边e,G-e中有K-N+1个独立回路,且

任取一个包含e的回路C,显然独立于之前的回路

任意两个包含e的回路C1与C2,C12=C1+C2是G-e的回路,C2不独立

故能且仅能增加一个包含e的独立回路

从而G中恰有(K+1)-N+1个独立回路,证毕”

另外,树只要添加一条边肯定成环,这是归纳最开始使用到的地方

  1. #include<iostream>
  2. #include<algorithm>
  3. #include<cstdio>
  4. #include<cstring>
  5. #include<cstdlib>
  6. #include<cmath>
  7. #include<string>
  8. #include<vector>
  9. #include<stack>
  10. #include<queue>
  11. #include<set>
  12. #include<map>
  13. #include<bitset>
  14. #define rep(i,j,k) for(register int i=j;i<=k;i++)
  15. #define rrep(i,j,k) for(register int i=j;i>=k;i--)
  16. #define erep(i,u) for(register int i=head[u];~i;i=nxt[i])
  17. #define iin(a) scanf("%d",&a)
  18. #define lin(a) scanf("%lld",&a)
  19. #define din(a) scanf("%lf",&a)
  20. #define s0(a) scanf("%s",a)
  21. #define s1(a) scanf("%s",a+1)
  22. #define print(a) printf("%lld",(ll)a)
  23. #define enter putchar('\n')
  24. #define blank putchar(' ')
  25. #define println(a) printf("%lld\n",(ll)a)
  26. #define IOS ios::sync_with_stdio(0)
  27. using namespace std;
  28. const int MAXN = 3e5+11;
  29. const double EPS = 1e-7;
  30. typedef long long ll;
  31. typedef unsigned long long ull;
  32. const ll MOD = 1e9+7;
  33. unsigned int SEED = 17;
  34. const ll INF = 1ll<<60;
  35. ll read(){
  36. ll x=0,f=1;register char ch=getchar();
  37. while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
  38. while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
  39. return x*f;
  40. }
  41. int to[MAXN<<1],nxt[MAXN<<1];ll cost[MAXN<<1];
  42. int head[MAXN<<1],tot;
  43. void init(){
  44. memset(head,-1,sizeof head);
  45. tot=0;
  46. }
  47. void add(int u,int v,ll w){
  48. to[tot]=v;
  49. cost[tot]=w;
  50. nxt[tot]=head[u];
  51. head[u]=tot++;
  52. swap(u,v);
  53. to[tot]=v;
  54. cost[tot]=w;
  55. nxt[tot]=head[u];
  56. head[u]=tot++;
  57. }
  58. bool vis[MAXN];
  59. ll dis[MAXN],tot2;
  60. ll a[MAXN],b[66],n;
  61. void dfs(int u,int fa){
  62. vis[u]=1;
  63. erep(i,u){
  64. ll v=to[i],w=cost[i];
  65. if(v==fa)continue;
  66. if(!vis[v]){
  67. dis[v]=dis[u]^w;
  68. dfs(v,u);
  69. }else{
  70. a[++tot2]=dis[u]^dis[v]^w;//环的异或值
  71. }
  72. }
  73. }
  74. void cal(int n){
  75. memset(b,0,sizeof b);
  76. rep(i,1,n){
  77. rrep(j,62,0){
  78. if(a[i]>>j&1){
  79. if(b[j]) a[i]^=b[j];
  80. else{
  81. b[j]=a[i];
  82. rrep(k,j-1,0) if(b[k]&&(b[j]>>k&1))b[j]^=b[k];
  83. rep(k,j+1,62) if(b[k]>>j&1) b[k]^=b[j];
  84. break;
  85. }
  86. }
  87. }
  88. }
  89. }
  90. int main(){
  91. int n,m;
  92. while(cin>>n>>m){
  93. init();
  94. rep(i,1,m){
  95. int u=read();
  96. int v=read();
  97. ll w=read();
  98. add(u,v,w);
  99. }
  100. tot2=0;
  101. memset(vis,0,sizeof vis);
  102. memset(dis,0,sizeof dis);
  103. dfs(1,-1);
  104. cal(tot2);
  105. ll ans=dis[n];
  106. rep(i,0,62) ans=max(ans,ans^b[i]);
  107. println(ans);
  108. }
  109. return 0;
  110. }

BZOJ - 2115 独立回路 线性基的更多相关文章

  1. BZOJ 2115: [Wc2011] Xor 线性基 dfs

    https://www.lydsy.com/JudgeOnline/problem.php?id=2115 每一条从1到n的道路都可以表示为一条从1到n的道路异或若干个环的异或值. 那么把全部的环丢到 ...

  2. BZOJ 2115 [Wc2011] Xor ——线性基

    [题目分析] 显然,一个路径走过两边是不需要计算的,所以我么找到一条1-n的路径,然后向该异或值不断异或简单环即可. 但是找出所有简单环是相当复杂的,我们只需要dfs一遍,找出所有的环路即可,因为所有 ...

  3. BZOJ.2115.[WC2011]Xor(线性基)

    题目链接 \(Description\) 给定一张无向带边权图(存在自环和重边).求一条1->n的路径,使得路径经过边的权值的Xor和最大.可重复经过点/边,且边权和计算多次. \(Soluti ...

  4. BZOJ 2460 [BeiJing2011]元素 ——线性基

    [题目分析] 线性基,由于最多有63个,只需要排序之后,动态的去维护线性基即可. [代码] #include <cstdio> #include <cstring> #incl ...

  5. bzoj 2460 [BeiJing2011]元素 (线性基)

    链接:https://www.lydsy.com/JudgeOnline/problem.php?id=2460 题意: 给你一堆矿石,矿石有a,b两种性质,取任意个矿石,满足取得的这些矿石a性质异或 ...

  6. BZOJ.2460.[BeiJing2011]元素(线性基 贪心)

    题目链接 线性基:https://blog.csdn.net/qq_36056315/article/details/79819714. \(Description\) 求一组矿石,满足其下标异或和不 ...

  7. BZOJ 2460 元素(贪心+线性基)

    显然线性基可以满足题目中给出的条件.关键是如何使得魔力最大. 贪心策略是按魔力排序,将编号依次加入线性基,一个数如果和之前的一些数异或和为0就跳过他. 因为如果要把这个数放进去,那就要把之前的某个数拿 ...

  8. bzoj 3811: 玛里苟斯【线性基+期望dp】

    这个输出可是有点恶心啊--WA*inf,最后抄了别人的输出方法orz 还有注意会爆long long,要开unsigned long long 对于k==1,单独考虑每一位i,如果这一位为1则有0.5 ...

  9. BZOJ 2460: [BeiJing2011]元素 线性基

    2460: [BeiJing2011]元素 Description 相传,在远古时期,位于西方大陆的 Magic Land 上,人们已经掌握了用魔法矿石炼制法杖的技术.那时人们就认识到,一个法杖的法力 ...

随机推荐

  1. Eclipse右击jsp没有运行选项

    maven项目低级错误,没有更新maven资源库.....更新后就运行起来了

  2. HighCharts SVN IReport进行PDF报表设计--模板

    BOS物流项目笔记第十五天 HIghcharts是很强大的图表绘制插件,它是基于纯js绘制的.当然地,对于图表也会有很多操作了.下面就我工作时遇到的一些比较常见的highcharts的操作进行小结,不 ...

  3. Solidity notes

    1. 查询transaction历史记录 https://forum.ethereum.org/discussion/2116/in-what-ways-can-storage-history-be- ...

  4. Solidity开发、测试、部署

    这篇文章很详细的列举了几种方式来开始solidity开发: https://medium.com/@davekaj/solidity-tips-and-tricks-for-beginners-bui ...

  5. pip镜像源配置

    #配置文件路径:%HOME%\pip\pip.ini,不存在新建即可 #在 Windows 2000 以上版本里,%HOME% 目录指的是系统盘下的“\Documents and Settings\你 ...

  6. c++(重载等号=操作为深拷贝)

    // ConsoleApplication19.cpp : 定义控制台应用程序的入口点. // #pragma warning(disable:4996) #include "stdafx. ...

  7. Introduction to Partial View

    By Jignesh Trivedi on May 14, 2015 http://www.c-sharpcorner.com/UploadFile/ff2f08/partial-view-in-mv ...

  8. whereis libjpeg.so.7

    在服务器上调用import ImageFont时报如下错误 ImportError: The _imagingft C module is not installed (服务器为Centos5.5, ...

  9. 使用Boost库(1)

    如何说服你的公司.组织使用Boost库 one of the most highly regarded and expertly designed C++ library projects in th ...

  10. python之numpy文件操作

    目录 numpy 中的文件操作总结 CVS文件 多维数据的存取 numpy 的便捷文件存取 numpy 中的文件操作总结 CVS文件 CSV (Comma‐Separated Value,逗号分隔值) ...