zoukankan      html  css  js  c++  java
  • luoguP3258 [JLOI2014]松鼠的新家 题解(树上差分)

    P3258 [JLOI2014]松鼠的新家  题目

    树上差分:树上差分总结

    #include<iostream>
    #include<cstdlib>
    #include<cstdio>
    #include<cmath>
    #include<cstring>
    #include<algorithm>
    #include<iomanip>
    #include<ctime>
    #include<queue>
    #include<stack>
    #define rg register
    #define lst long long
    #define N 300050
    using namespace std;
    
    int n,K,cnt,ans;
    struct EDGE{
        int to,nxt;
    }edge[N<<1];
    int head[N],an[N];
    int fa[N],v[N],deep[N];
    int f[N][25];
    
    inline int read()
    {
        rg int s=0,m=1;rg char ch=getchar();
        while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();
        if(ch=='-')m=-1,ch=getchar();
        while(ch>='0'&&ch<='9')s=(s<<3)+(s<<1)+ch-'0',ch=getchar();
        return s*m;
    }
    
    inline void add(rg int p,rg int q)
    {
        edge[++cnt]=(EDGE){q,head[p]};
        head[p]=cnt;
    }
    
    void dfs(rg int now,rg int fm,rg int dep)
    {
        fa[now]=fm;deep[now]=dep;
        f[now][0]=fa[now];
        for(rg int i=1;i<=20;++i)
            f[now][i]=f[f[now][i-1]][i-1];
        for(rg int i=head[now];i;i=edge[i].nxt)
        {
            rg int qw=edge[i].to;
            if(qw!=fm)
                dfs(qw,now,dep+1);
        }
    }
    
    inline int lca(rg int p,rg int q)
    {
        if(deep[p]<deep[q])swap(p,q);
        while(deep[p]>deep[q])
            for(rg int i=20;i>=0;--i)
                if(deep[f[p][i]]>=deep[q])
                    p=f[p][i];
        while(p!=q)
        {
            for(rg int i=20;i>=0;--i)
                if(f[p][i]!=f[q][i])
                    p=f[p][i],q=f[q][i];
            if(fa[p]==fa[q])
                p=q=fa[p];
        }
        return p;
    }
    
    inline void Insert(rg int p,rg int q)
    {
        v[p]++,v[q]++;
          rg int LCA=lca(p,q);
    //    printf("lca(%d,%d)=%d
    ",p,q,LCA);
          v[LCA]--,v[fa[LCA]]--;
    }
    
    void sum(rg int now)
    {
        for(rg int i=head[now];i;i=edge[i].nxt)
        {
            rg int qw=edge[i].to;
            if(qw!=fa[now])
            {
                sum(qw);
                v[now]+=v[qw];
            }
        }
    }
    
    int main()
    {
        n=read();
        for(rg int i=1;i<=n;++i)an[i]=read();
        for(rg int i=1;i<n;++i)
        {
            rg int p=read(),q=read();
            add(p,q),add(q,p);
        }
          dfs(1,0,1);
        for(rg int i=1;i<n;++i)
        {
            Insert(an[i],an[i+1]);
        }
    //    for(rg int i=1;i<=n;++i)cout<<deep[i]<<" ";cout<<endl;
    /*    for(rg int i=1;i<=n;++i)
        {
            for(rg int j=0;j<=2;j++)
            {
                printf("f[%d][%d]=%d ",i,j,f[i][j]);
            }
            cout<<endl;
        }
        cout<<endl;*/
        add(0,1);
        sum(0);
        for(rg int i=2;i<=n;++i)v[an[i]]--;
        for(rg int i=1;i<=n;++i)printf("%d
    ",v[i]);
        return 0;
    }
  • 相关阅读:
    树系列学习--树的定义(-)
    idea live template高级知识, 进阶(给方法,类,js方法添加注释)(二)
    mysql 查询所有子节点的相关数据
    maven util 类 添加 service
    idea live template高级知识, 进阶(给方法,类,js方法添加注释)
    idea live template
    eclipse 好用的插件总结
    Spirng+SpringMVC+Maven+Mybatis+MySQL项目搭建
    Mac OS 的命令行 总结
    jsp,jquery,spring mvc 实现导出文件
  • 原文地址:https://www.cnblogs.com/cjoierljl/p/8728194.html
Copyright © 2011-2022 走看看