洛谷 P4114 Qtree1(边树剖)

洛谷 同时被 2 个专栏收录
149 篇文章 0 订阅
18 篇文章 0 订阅

 

 

const int N=1e5+5;

    int n,m;
    int i,j,k;
    int a[N];
    struct Node
    {
        int l,r;
        int maxx;
        #define lson id<<1
        #define rson id<<1|1
    }t[N<<2];
    struct Edge
    {
        int u,v,w;
    }E[N];
    vector<pii> G[N];

int fa[N],son[N],sz[N],dep[N];
void dfs1(int u,int f)
{
    dep[u]=dep[f]+1;
    fa[u]=f;
    sz[u]=1;
    for(int i=0;i<G[u].size();i++){
        int v=G[u][i].fr;
        if(v==f) continue;
        a[v]=G[u][i].sc;
        dfs1(v,u);
        sz[u]+=sz[v];
        if(sz[son[u]]<sz[v]) son[u]=v;
    }
}

int top[N],tot=0,tree[N],id[N];
void dfs2(int u,int f)
{
    top[u]=f;
    id[u]=++tot;
    tree[tot]=u;
    if(!son[u]) return ;
    dfs2(son[u],f);
    for(int i=0;i<G[u].size();i++){
        int v=G[u][i].fr;
        if(v==son[u] || v==fa[u]) continue;
        dfs2(v,v);
    }
}

void push_up(int id)
{
    t[id].maxx=max(t[lson].maxx,t[rson].maxx);
}

void build(int l,int r,int id)
{
    t[id].l=l,t[id].r=r;
    if(l==r) t[id].maxx=a[tree[l]];
    else{
        int mid=l+r>>1;
        build(l,mid,lson);
        build(mid+1,r,rson);
        push_up(id);
    }
}

void update(int pos,int val,int id)
{
    int L=t[id].l,R=t[id].r;
    if(L==R) t[id].maxx=val;
    else {
        int mid=L+R>>1;
        if(mid>=pos) update(pos,val,lson);
        else update(pos,val,rson);
        push_up(id);
    }
}

int query(int l,int r,int id)
{
    int L=t[id].l,R=t[id].r;
    if(L>=l && r>=R) return t[id].maxx;
    else {
        int mid=L+R>>1;
        int ans=0;
        if(mid>=l) ans=max(ans,query(l,r,lson));
        if(r>=mid+1) ans=max(ans,query(l,r,rson));
        return ans;
    }
}

#define nx top[x]
#define ny top[y]

int ask(int x,int y)
{
    int ans=0;
    while(nx!=ny)
    {
        if(dep[nx]<dep[ny]) swap(x,y);
        ans=max(ans,query(id[nx],id[x],1));
        x=fa[nx];
    }
    if(dep[x]>dep[y]) swap(x,y);
    return max(ans,query(id[x]+1,id[y],1));
}

int main()
{
    //IOS;
    while(~sd(n)){
        int x,y,w;
        int tot=0;
        for(int i=1;i<n;i++){
            sddd(x,y,w);
            G[x].pb(mp(y,w));
            G[y].pb(mp(x,w));
            E[++tot]=Edge{x,y,w};
        }
        dfs1(1,0); dfs2(1,1);
        build(1,n,1);
        char ch[10];
        ss(ch);
        while(ch[0]!='D'){
            sdd(x,y);
            if(ch[0]=='C'){
                int u=E[x].u,v=E[x].v;
                if(fa[v]==u) swap(u,v);
                update(id[u],y,1);
            } else if(ch[0]=='Q'){
                int ans=(x==y?0:ask(x,y));
                pd(ans);
            }
            ss(ch);
        }
    }
    //PAUSE;
    return 0;
}

 

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

相关推荐
<p> <span style="font-size:14px;color:#337FE5;">【为什么学爬虫?】</span> </p> <p> <span style="font-size:14px;">       1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到!</span> </p> <p> <span style="font-size:14px;">       2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站</span> </p> <p> <br /> </p> <span style="font-size:14px;color:#337FE5;">【课程设计】</span> <p class="ql-long-10663260"> <span> </span> </p> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: </p> <ol> <li class="" style="font-size:11pt;color:#494949;"> 网络请求:模拟浏览器的行为从网上抓取数据。 </li> <li class="" style="font-size:11pt;color:#494949;"> 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 </li> <li class="" style="font-size:11pt;color:#494949;"> 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 </li> </ol> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: </p> <ol> <li class="" style="font-size:11pt;color:#494949;"> 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 </li> <li class="" style="font-size:11pt;color:#494949;"> Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 </li> </ol> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 </p> <p style="font-size:11pt;color:#494949;">   </p> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! </p> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> <br /> </p> <p> <br /> </p> <p> <span style="font-size:14px;background-color:#FFFFFF;color:#337FE5;">【课程服务】</span> </p> <p> <span style="font-size:14px;">专属付费社群+定期答疑</span> </p> <p> <br /> </p> <p class="ql-long-24357476"> <span style="font-size:16px;"><br /> </span> </p> <p> <br /> </p> <p class="ql-long-24357476"> <span style="font-size:16px;"></span> </p>
©️2020 CSDN 皮肤主题: 酷酷鲨 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值