Master of Data Structure 虚树

本文介绍了如何掌握数据结构中的虚树概念,并通过实际例子展示了如何建立虚树以及在虚树上进行暴力求解问题。同时,文章讨论了如何在虚树中维护两点间实际节点的数量,提供了一种模拟方法,尽管代码实现较为复杂。
摘要由CSDN通过智能技术生成

链接
m<2000
建虚树后暴力
维护虚树中两点间的实际点的个数 模拟即可
巨丑的代码

#pragma GCC optimize(2)
#include<bits/stdc++.h>
#define ls rt<<1
#define rs rt<<1|1
#define pb push_back
#define fi first
#define se second
#define mkp make_pair
#define yes puts("YES")
#define no puts("NO")
#define err puts("-1")
#define ios ios::sync_with_stdio(0);
using namespace std;
typedef long long LL;
typedef pair<int, int> PII;
typedef vector<int> VI;
const int maxn = 5e5 + 6;
const LL inf = 0x3f3f3f3f3f3f3f3f;
const int mod = 998244353;
LL qp(LL x,LL y)
{
   
    LL ans=1;
    x%=mod;
    while(y)
    {
   
        if(y&1)
            ans=ans*x%mod;
        x=x*x%mod;
        y>>=1;
    }
    return ans;
}
LL inv(LL x)
{
   
    return qp(x,mod-2);
}

//head
int lgN,n,m,op[maxn],dfn[maxn],b[maxn],u[maxn],v[maxn],k[maxn],dep[maxn],tot;
int fa[maxn][30];
VI G[maxn],fake[maxn];
void dfs(int u,int f)
{
   
    dep[u]=dep[f]+1;
    fa[u][0]=f;
    dfn[u]=++tot;
    for(int i=1; i<=lgN; i++)
    {
   
        fa[u][i]=fa[fa[u][i-1]][i-1];
    }
    for(int v:G[u])
        if(v!=f)
        {
   
            dfs(v,u);
        }
}
int anc[maxn],dp[maxn];
void dfs1(int u,int f)
{
   
    anc[u]=f;
    dp[u]=dp[f]+1;
    for(int v:fake[u])
    {
   
        dfs1(v,u);
    }
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值