#线性基,深搜#洛谷 4151 最大XOR和路径

本文介绍了一种寻找无向连通图中从1号节点到N号节点的最大XOR和路径的方法。通过深度优先搜索确定链路上的XOR值,并利用线性基处理环路贡献,最终得出最优路径。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目

考虑一个边权为非负整数的无向连通图,节点编号为 111NNN,试求出一条从 111 号节点到 NNN 号节点的路径,使得路径上经过的边的权值的 XOR 和最大。


分析

首先这个XOR和应该是一条链加上一个个环,异或是可以抵消的,首先链上的东西可以深搜搞定,但是环呢,可以把环的贡献扔到线性基里,最后更新答案即可


代码

#include <cstdio>
#include <cctype>
#define rr register
using namespace std;
typedef long long ll; ll rec[61],f[50001];
struct node{int y; ll w; int next;}e[200011];
int n,k=1,ls[50001]; bool v[50001];
inline ll iut(){
    rr ll ans=0; rr char c=getchar();
    while (!isdigit(c)) c=getchar();
    while (isdigit(c)) ans=(ans<<3)+(ans<<1)+(c^48),c=getchar();
    return ans;
}
inline void add(ll x){
    for (rr int i=60;i>=0;--i)
    if ((x>>i)&1){
        if (!rec[i]){
            rec[i]=x;
            return;
        }
        x^=rec[i];
    }
}
inline void dfs(int x,ll now){
    f[x]=now; v[x]=1;
    for (rr int i=ls[x];i;i=e[i].next)
    if (!v[e[i].y]) dfs(e[i].y,now^e[i].w);
        else add(now^e[i].w^f[e[i].y]);
}
inline ll query(ll x){
    for (rr int i=60;i>=0;--i)
    if ((x^rec[i])>x) x^=rec[i];
    return x;
}
signed main(){
    n=iut();
    for (rr int m=iut();m;--m){
        rr int x=iut(),y=iut(); rr ll w=iut();
        e[++k]=(node){y,w,ls[x]}; ls[x]=k;
        e[++k]=(node){x,w,ls[y]}; ls[y]=k;
    }
    dfs(1,0);
    return !printf("%lld",query(f[n]));
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值