OI学习笔记之数据结构——带权并查集

本文深入探讨带权并查集的概念与应用,这是一种高级的数据结构,不仅支持基础的查询和合并操作,还能维护子节点与父节点间的关系,特别适用于处理元素间的权重或距离信息。文中详细解释了带权并查集的两个基本操作:merge和find,并通过实例说明了其在解决特定问题中的作用。

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

带权并查集是一种并查集的操作,其功能与基础并查集相同,支持查询和合并操作。除此之外,带权并查集还维护了子节点与父节点之间的关系,在一个有序的集合中,某个元素到根节点的距离(例:NOI2002银河英雄传说),其操作是除了维护节点关系数组f以外,还维护了多个能表示元素之间关系的数组如value等


带权并查集的基本操作1——merge

//比如要维护有序队列中某个点离祖宗的距离
inline void merge(int x,int y)
{
    int f1=find(x),f2=find(y);
    if(f1!=f2)
    {
       f[f1]=f2;
       value[f1]+=sum[f2];
       sum[f2]+=sum[f1];
       sum[f1]=0;
    }
    returnl
}

带权并查集的基本操作二——查询
在合并后,被合并集合的信息并不是立马更改,而是在一次查询中全部更改
注意信息的修改需要在回溯的过程中实现

inline int find(int k)
{
    if(f[k]==k) return f[k];
    int fa=find(f[k]);
    value[k]+=value[f[k]];
    return f[k]=fa;//路径压缩
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值