传送门

一遍AC,开心!

$Link-Cut-Tree$最后一题

//BZOJ 1180
//by Cydiater
//2016.9.18
#include <iostream>
#include <cstdio>
#include <cstring>
#include <string>
#include <algorithm>
#include <queue>
#include <map>
#include <ctime>
#include <cmath>
#include <iomanip>
#include <cstdlib>
using namespace std;
#define ll long long
#define up(i,j,n)        for(int i=j;i<=n;i++)
#define down(i,j,n)        for(int i=j;i>=n;i--)
const int MAXN=1e6+5;
const int oo=0x3f3f3f3f;
inline int read(){
    char ch=getchar();int x=0,f=1;
    while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();}
    while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
    return x*f;
}
int N,q[MAXN],top=0,M,nodea,nodeb,node,v;
char op[15];
struct Tree{
    int son[2],v,sum,tag,fa;
}t[MAXN];
namespace solution{
    inline bool get(int node){return t[t[node].fa].son[1]==node;}
    inline bool isroot(int node){return t[t[node].fa].son[0]!=node&&t[t[node].fa].son[1]!=node;}
    inline bool updata(int node){
        if(node){
            t[node].sum=t[node].v;
            if(t[node].son[0])t[node].sum+=t[t[node].son[0]].sum;
            if(t[node].son[1])t[node].sum+=t[t[node].son[1]].sum;
        }
    }
    inline void downit(int node){
        if(t[node].tag){
            t[t[node].son[0]].tag^=1;t[t[node].son[1]].tag^=1;
            swap(t[node].son[0],t[node].son[1]);
            t[node].tag^=1;
        }
    }
    inline void rotate(int node){
        int old=t[node].fa,oldf=t[old].fa,which=get(node);
        if(!isroot(old))t[oldf].son[t[oldf].son[1]==old]=node;
        t[old].son[which]=t[node].son[which^1];t[t[old].son[which]].fa=old;
        t[node].son[which^1]=old;t[node].fa=oldf;t[old].fa=node;
        updata(old);updata(node);
    }
    inline void splay(int node){
        top=0;q[++top]=node;
        for(int i=node;!isroot(i);i=t[i].fa)q[++top]=t[i].fa;
        down(i,top,1)downit(q[i]);
        while(!isroot(node)){
            int old=t[node].fa,oldf=t[old].fa;
            if(!isroot(old))rotate(get(node)==get(old)?old:node);
            rotate(node);
        }
    }
    inline void access(int node){
        int tmp=0;
        while(node){
            splay(node);t[node].son[1]=tmp;
            updata(node);tmp=node;
            node=t[node].fa;
        }
    }
    inline void Reverse(int node){
        access(node);splay(node);t[node].tag^=1;
    }
    inline void Link(int noda,int nodb){
        Reverse(noda);t[noda].fa=nodb;
    }
    inline void Cut(int noda,int nodb){
        Reverse(noda);access(nodb);splay(nodb);
        t[nodb].son[0]=t[noda].fa=0;
    }
    inline int find(int node){
        access(node);splay(node);
        while(t[node].son[0])node=t[node].son[0];
        return node;
    }
    inline void LCA(int noda,int nodb){
        Reverse(nodb);access(noda);splay(noda);
    }
    inline void change(int node,int v){
        access(node);
        splay(node);
        t[node].v=v;updata(node);
    }
    void init(){
        N=read();
        up(i,1,N){
            t[i].v=t[i].sum=read();
            t[i].son[0]=t[i].son[1]=t[i].fa=0;
        }
    }
    void slove(){
        M=read();
        while(M--){
            scanf("%s",op);
            if(op[0]=='b'){
                nodea=read();nodeb=read();
                if(find(nodea)==find(nodeb))puts("no");
                else{
                    puts("yes");
                    Link(nodea,nodeb);
                }
            }
            if(op[0]=='p'){
                node=read();v=read();
                change(node,v);
            }
            if(op[0]=='e'){
                nodea=read();nodeb=read();
                if(find(nodea)==find(nodeb)){
                    LCA(nodea,nodeb);
                    printf("%d\n",t[nodea].sum);
                }
                else puts("impossible");
            }
        }
    }
}
int main(){
    //freopen("input.in","r",stdin);
    using namespace solution;
    init();
    slove();
    return 0;
}

BZOJ1180: [CROATIAN2009]OTOCI的更多相关文章

  1. BZOJ1180 [CROATIAN2009]OTOCI LCT

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1180 本题和BZOJ2843一样. BZOJ2843 极地旅行社 LCT 题意概括 有n座岛 每座 ...

  2. BZOJ2843极地旅行社&BZOJ1180[CROATIAN2009]OTOCI——LCT

    题目描述 给出n个结点以及每个点初始时对应的权值wi.起始时点与点之间没有连边.有3类操作:  1.bridge A B:询问结点A与结点B是否连通. 如果是则输出“no”.否则输出“yes”,并且在 ...

  3. BZOJ1180 [CROATIAN2009]OTOCI 【LCT】

    题目 给出n个结点以及每个点初始时对应的权值wi.起始时点与点之间没有连边.有3类操作: 1.bridge A B:询问结点A与结点B是否连通.如果是则输出"no".否则输出&qu ...

  4. [bzoj1180][CROATIAN2009]OTOCI_LCT

    OTOCI bzoj-1180 CROATIAN-2009 题目大意:给你n个离散的点,m个操作.支持:两点加边(保证还是森林),修改单点权值,询问两点是否联通,查询联通两点之间路径权值. 注释:$1 ...

  5. BZOJ 1180: [CROATIAN2009]OTOCI [LCT]

    1180: [CROATIAN2009]OTOCI Time Limit: 50 Sec  Memory Limit: 162 MBSubmit: 961  Solved: 594[Submit][S ...

  6. BZOJ 1180: [CROATIAN2009]OTOCI

    1180: [CROATIAN2009]OTOCI Time Limit: 50 Sec  Memory Limit: 162 MBSubmit: 989  Solved: 611[Submit][S ...

  7. 1180: [CROATIAN2009]OTOCI(LCT)

    1180: [CROATIAN2009]OTOCI Time Limit: 50 Sec  Memory Limit: 162 MBSubmit: 1200  Solved: 747[Submit][ ...

  8. 1180: [CROATIAN2009]OTOCI

    1180: [CROATIAN2009]OTOCI Time Limit: 50 Sec  Memory Limit: 162 MBSubmit: 1032  Solved: 638[Submit][ ...

  9. 【BZOJ1180】: [CROATIAN2009]OTOCI & 2843: 极地旅行社 LCT

    竟然卡了我....忘记在push_down先下传父亲的信息了....还有splay里for():卡了我10min,但是双倍经验还是挺爽的,什么都不用改. 感觉做的全是模板题,太水啦,不能这么水了... ...

随机推荐

  1. 比较Windows Azure 网站(Web Sites), 云服务(Cloud Services)and 虚机(Virtual Machines)

    Windows Azure提供了几个部署web应用程序的方法,比如Windows Azure网站.云服务和虚拟机.你可能无法确定哪一个最适合您的需要,或者你可能清楚的概念,比如IaaS vs PaaS ...

  2. js的offsetWidth,offsetHeight,offsetLeft,offsetTop

    js的offsetWidth,offsetHeight,offsetLeft,offsetTop

  3. ASP.NET Web API 实现客户端Basic(基本)认证 之简单实现

    优点是逻辑简单明了.设置简单. 缺点显而易见,即使是BASE64后也是可见的明文,很容易被破解.非法利用,使用HTTPS是一个解决方案. 还有就是HTTP是无状态的,同一客户端每次都需要验证. 实现: ...

  4. 异步dcfifo的读写

    异步dcfifo的原理 Dcfifo即是Double clk fifo,意思是双时钟的fifo.或许你现在还不知道什么是fifo,那我就先从fifo(就是同步fifo,不过同步fifo在实际运用中比较 ...

  5. 柯尔莫可洛夫-斯米洛夫检验(Kolmogorov–Smirnov test,K-S test)

    柯尔莫哥洛夫-斯米尔诺夫检验(Колмогоров-Смирнов检验)基于累计分布函数,用以检验两个经验分布是否不同或一个经验分布与另一个理想分布是否不同. 在进行cumulative probab ...

  6. MATLAB 中NORM运用

    格式:n=norm(A,p)功能:norm函数可计算几种不同类型的矩阵范数,根据p的不同可得到不同的范数 以下是Matlab中help norm 的解释 NORM   Matrix or vector ...

  7. java多态实现原理

    众所周知,多态是面向对象编程语言的重要特性,它允许基类的指针或引用指向派生类的对象,而在具体访问时实现方法的动态绑定.C++ 和 Java 作为当前最为流行的两种面向对象编程语言,其内部对于多态的支持 ...

  8. android中的屏幕单位介绍

    1.px (pixels)(像素):是屏幕的物理像素点,与密度相关,密度大了,单位面积上的px 会比较多.通常不推荐使用这个. 2.dip 或dp(与密度无关的像素):一个基于density(密度)的 ...

  9. .NET中的垃圾回收

    目录 l         导言 l         关于垃圾回收 l         垃圾回收算法 m        应用程序根(Application Roots) l         实现 m   ...

  10. iOS开发小技巧--TableView Group样式中控制每个section之间的距离

    一.TableView的Group样式中,默认的每个section都有sectionHeader和sectionFooter,只要调整这两个的大小就可以实现section之前的间距扩大或缩小 二.项目 ...