P4151 最大XOR和路径 线性基

Posted Aragaki

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了P4151 最大XOR和路径 线性基相关的知识,希望对你有一定的参考价值。

题解见:https://www.luogu.org/problemnew/solution/P4151

其实就是找出所有环 把环上所有边异或起来得到的值扔到线性基里面

然后随便走一条从1~n的链 最后求最大异或和即可

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
#define LL long long
LL num[70];
bool insert(LL x) {
        for (int i = 63; i >= 0; i--)
                if ((x >> i) & 1) {
                        if (!num[i]) {
                                num[i] = x;
                                return true;
                        }
                        x ^= num[i];
                }
        return false;
}
LL query(LL x) {
        LL res = x;
        for (int i = 63; i >= 0; i--)
                if ((res ^ num[i]) > res)
                        res ^= num[i];
        return res;
}
struct edge {
        int to, next;
        LL w;
} e[200010];
int head[50010], ecnt;
inline void adde(int from, int to, LL w) {
        e[++ecnt] = (edge) {to, head[from], w}, head[from] = ecnt;
        e[++ecnt] = (edge) {from, head[to], w}, head[to] = ecnt;
}
int vis[50010];
LL del[50010];
void dfs(int u, LL res) {
        del[u] = res, vis[u] = 1;
        for (int i = head[u]; i; i = e[i].next)
                if (!vis[e[i].to])
                        dfs(e[i].to, res ^ e[i].w);
                else
                        insert(res ^ e[i].w ^ del[e[i].to]);
}
int main() {
        int n, m, a, b;
        LL c;
        scanf("%d%d", &n, &m);
        for (int i = 1; i <= m; i++)
                scanf("%d%d%lld", &a, &b, &c), adde(a, b, c);
        dfs(1, 0);
        printf("%lld\n", query(del[n]));
}

 

以上是关于P4151 最大XOR和路径 线性基的主要内容,如果未能解决你的问题,请参考以下文章

线性基题表(已完成)

SCOI2016 幸运数字

Codeforces 938G 线段树分治 线性基 可撤销并查集

Xor HYSBZ - 2115 (线性基)

bzoj2115 [Wc2011] Xor——高斯消元 & 异或线性基

CF.724G.Xor-matic Number of the Graph(线性基)