zoukankan      html  css  js  c++  java
  • [BZOJ 3647]

    BZOJ 3647——可持久化并查集加强版

    不会可持久化并查集先去做http://www.cnblogs.com/Fish-/p/8242582.html.

    幼稚的以为直接交原来的就好了,结果T了!

    加个路径压缩,but一直RE,请了几位大神还是解决不了。。所以先留个坑。。

    #include<cstdio>
    #include<iostream>
    #include<algorithm>
    using namespace std;
    #define maxn 300050
    int cnt=0,ls[maxn*40],rs[maxn*40],root[maxn],sz,key[maxn*40],n,m,i,v[maxn*40];
    int read(){
        int w=0;char c=getchar();
        while(c<48||c>57) c=getchar();
        while(c>=48&&c<=57){
            w=w*10+c-48;
            c=getchar();
        }
        return w;
    }
    void build(int &p,int l,int r){
        p=++cnt;
        if(l==r) {key[p]=l;return;}
        if(l!=r){
            int mid=(l+r)/2;
            build(ls[p],l,mid);
            build(rs[p],mid+1,r);
        }
    }
    void Modify(int &p,int cmp,int l,int r,int loc,int val){
        if(v[p]!=i){
        p=++cnt;ls[p]=ls[cmp];rs[p]=rs[cmp];v[p]=i;}
        if(l==r){
            key[p]=val;
        }
        if(l!=r){
            int mid=(l+r)>>1;
            if(loc<=mid){
                Modify(ls[p],ls[cmp],l,mid,loc,val);
            }
            else{
                Modify(rs[p],rs[cmp],mid+1,r,loc,val);
            }
        }
    }
    inline int query(int version,int l,int r,int loc){
        int mid;
        while(l!=r){
            mid=(l+r)>>1;
            if(loc<=mid) version=ls[version],r=mid;
            else version=rs[version],l=mid+1;
        }
        return key[version];
    }
    int find(int version,int loc){
        int fa=query(root[version],1,n,loc);
        if(fa==loc) return fa;
        int anc=find(version,fa);
        Modify(root[version],root[version],1,n,loc,anc);
        return anc;
    }
    int main()
    {
        int x,y,l,r,k,opt,lastans=0;
        n=read();m=read();
        build(root[0],1,n);
        for(i=1;i<=m;i++){
            opt=read();x=read()^lastans;
            if(opt==1){
                y=read()^lastans;
                Modify(root[i],root[i-1],1,n,find(root[i-1],x),find(root[i-1],y));
            }
            else if(opt==2) root[i]=root[x];
            else{
                y=read()^lastans;
                root[i]=root[i-1];
                lastans=(find(i,x)==find(i,y));
                if(lastans) printf("1
    ");
                else printf("0
    ");
            }
        }
        //printf("%d
    ",cnt);
    }
    
  • 相关阅读:
    新项目调试思路
    cmstop核心
    jquery获取li中的各项属性值attr
    mysql表设计
    SQLServer系统表使用简介(sysobjects、syscolumns、syscomments等)转载
    死锁查询和处理
    this 关键字的用法
    C# 线程
    C# WCF的通信模式
    C# WCF之用接口创建服务契约、部署及客户端连接
  • 原文地址:https://www.cnblogs.com/Fish-/p/8253032.html
Copyright © 2011-2022 走看看