LCT模版

来源:互联网 发布:北京软件退税政策 编辑:程序博客网 时间:2024/05/16 15:23

相关资料点击打开链接

#include <iostream>#include <string>#include <vector>#include <map>#include <queue>#include <algorithm>#include <cstring>#include <cmath>#include <set>#include <vector>using namespace std;template <class T>inline bool rd(T &ret) {char c; int sgn;if (c = getchar(), c == EOF) return 0;while (c != '-' && (c<'0' || c>'9')) c = getchar();sgn = (c == '-') ? -1 : 1;ret = (c == '-') ? 0 : (c - '0');while (c = getchar(), c >= '0'&&c <= '9') ret = ret * 10 + (c - '0');ret *= sgn;return 1;}template <class T>inline void pt(T x) {if (x <0) {putchar('-');x = -x;}if (x>9) pt(x / 10);putchar(x % 10 + '0');}typedef long long ll;typedef pair<int, int> pii;const int N = 30005;const int inf = 10000000;struct Node *null;struct Node {Node *fa, *ch[2];int size;int val, ma, sum, id;bool rev;inline void put() {}inline void clear(int _val, int _id) {fa = ch[0] = ch[1] = null;size = 1;rev = 0;id = _id;val = ma = sum = _val;}inline void push_up() {size = 1 + ch[0]->size + ch[1]->size;sum = ma = val;if (ch[0] != null) {sum += ch[0]->sum;ma = max(ma, ch[0]->ma);}if (ch[1] != null) {sum += ch[1]->sum;ma = max(ma, ch[1]->ma);}}inline void push_down() {if (rev) {ch[0]->flip();ch[1]->flip();rev = 0;}}inline void setc(Node *p, int d) {ch[d] = p;p->fa = this;}inline bool d() {return fa->ch[1] == this;}inline bool isroot() {return fa == null || fa->ch[0] != this && fa->ch[1] != this;}inline void flip() {if (this == null)return;swap(ch[0], ch[1]);rev ^= 1;}inline void go() {//从链头开始更新到thisif (!isroot())fa->go();push_down();}inline void rot() {Node *f = fa, *ff = fa->fa;int c = d(), cc = fa->d();f->setc(ch[!c], c);this->setc(f, !c);if (ff->ch[cc] == f)ff->setc(this, cc);else this->fa = ff;f->push_up();}inline Node*splay() {go();while (!isroot()) {if (!fa->isroot())d() == fa->d() ? fa->rot() : rot();rot();}push_up();return this;}inline Node* access() {//access后this就是到根的一条splay,并且this已经是这个splay的根了for (Node *p = this, *q = null; p != null; q = p, p = p->fa) {p->splay()->setc(q, 1);p->push_up();}return splay();}inline Node* find_root() {Node *x;for (x = access(); x->push_down(), x->ch[0] != null; x = x->ch[0]);return x;}void make_root() {access()->flip();}void cut() {//把这个点的子树脱离出去access();ch[0]->fa = null;ch[0] = null;push_up();}void cut(Node *x) {if (this == x || find_root() != x->find_root())return;else {x->make_root();cut();}}void link(Node *x) {if (find_root() == x->find_root())return;else {make_root(); fa = x;}}};Node pool[N], *tail;Node *node[N];void init(int n) {tail = pool;null = tail++;null->clear(0, 0);null->size = 0;for (int i = 1; i <= n; i++) {node[i] = tail++;node[i]->clear(0, i);}}void debug(Node *x) {if (x == null)return;x->put();debug(x->ch[0]);debug(x->ch[1]);}int main() {int n;init(n);return 0;}


HDU 5002

#include <stdio.h>#include <string.h>#include <iostream>#include <algorithm>#include <vector>#include <queue>#include <set>#include <map>#include <string>#include <math.h>#include <stdlib.h>#include <time.h>using namespace std;const int INF = 0x3f3f3f3f;const int MAXN = 100010;struct Node *null;struct Node{    Node *fa,*ch[2];    int val,size;    int same,add;    int rev;    int mm,mmc;    int sm,smc;    inline void clear(int _val){        fa = ch[0] = ch[1] = null;        val = _val; size = 1;        same = -INF;        add = 0;        mm = _val; mmc = 1;        sm = -INF; smc = 0;    }    inline void add_val(int _val,int num){        if(_val == -INF)return;        if(_val < sm)return;        if(_val == sm)smc += num;        else if(_val < mm){            sm = _val; smc = num;        }        else if(_val == mm){            mmc += num;        }        else{            sm = mm; smc = mmc;            mm = _val; mmc = num;        }    }    inline void push_up(){        size = 1 + ch[0]->size + ch[1]->size;        mm = sm = -INF;        mmc = smc = 0;        add_val(val,1);        add_val(ch[0]->mm,ch[0]->mmc);        add_val(ch[0]->sm,ch[0]->smc);        add_val(ch[1]->mm,ch[1]->mmc);        add_val(ch[1]->sm,ch[1]->smc);    }    inline void setc(Node *p,int d){        ch[d] = p;        p->fa = this;    }    inline bool d(){        return fa->ch[1] == this;    }    inline bool isroot(){        return fa == null || fa->ch[0] != this && fa->ch[1] != this;    }    inline void flip(){        if(this == null)return;        swap(ch[0],ch[1]);        rev ^= 1;    }    inline void update_add(int w){        if(this == null)return;        if(mm != -INF)mm += w;        if(sm != -INF)sm += w;        val += w;        add += w;    }    inline void update_same(int w){        if(this == null)return;        mm = w; mmc = size;        sm = -INF; smc = 0;        same = w;        val = w;        add = 0;    }    inline void push_down(){        if(same != -INF){            ch[0]->update_same(same);            ch[1]->update_same(same);            same = -INF;        }        if(add){            ch[0]->update_add(add);            ch[1]->update_add(add);            add = 0;        }        if(rev){            ch[0]->flip();            ch[1]->flip();            rev = 0;        }    }    inline void go(){        if(!isroot())fa->go();        push_down();    }    inline void rot(){        Node *f = fa, *ff = fa->fa;        int c = d(), cc = fa->d();        f->setc(ch[!c],c);        this->setc(f,!c);        if(ff->ch[cc] == f)ff->setc(this,cc);        else this->fa = ff;        f->push_up();    }    inline Node* splay(){        go();        while(!isroot()){            if(!fa->isroot())                d()==fa->d() ? fa->rot() : rot();            rot();        }        push_up();        return this;    }    inline Node* access(){        for(Node *p = this,*q = null; p != null; q = p, p = p->fa){            p->splay()->setc(q,1);            p->push_up();        }        return splay();    }    inline Node* find_root(){        Node *x;        for(x = access(); x->push_down(), x->ch[0] != null; x = x->ch[0]);        return x;    }    void make_root(){        access()->flip();    }    void cut(){        access();        ch[0]->fa = null;        ch[0] = null;        push_up();    }    void cut(Node *x){        if(this == x || find_root() != x->find_root())return;        else{            x->make_root();            cut();        }    }    void link(Node *x){        if(find_root() == x->find_root())return;        else {            make_root(); fa = x;        }    }};void SAME(Node *x,Node *y,int w){    x->access();    for(x = null; y != null; x = y, y = y->fa){        y->splay();        if(y->fa == null){            y->ch[1]->update_same(w);            x->update_same(w);            y->val = w;            y->push_up();            return;        }        y->setc(x,1);        y->push_up();    }}void ADD(Node *x,Node *y,int w){    x->access();    for(x = null; y != null; x = y, y = y->fa){        y->splay();        if(y->fa == null){            y->ch[1]->update_add(w);            x->update_add(w);            y->val += w;            y->push_up();            return;        }        y->setc(x,1);        y->push_up();    }}int MM,MMC;int SM,SMC;void ADD_VAL(int val,int num){    if(val == -INF)return;    if(val < SM)return;    if(val == SM)SMC += num;    else if(val < MM){        SM = val;        SMC = num;    }    else if(val == MM){        MMC += num;    }    else {        SM = MM; SMC = MMC;        MM = val; MMC = num;    }}void ask(Node *x,Node *y){    x->access();    for(x=null; y != null; x = y, y = y->fa){        y->splay();        if(y->fa == null){            MM = SM = -INF;            MMC = SMC = 0;            ADD_VAL(y->val,1);            ADD_VAL(y->ch[1]->mm,y->ch[1]->mmc);            ADD_VAL(y->ch[1]->sm,y->ch[1]->smc);            ADD_VAL(x->sm,x->smc);            ADD_VAL(x->mm,x->mmc);            return;        }        y->setc(x,1);        y->push_up();    }}Node pool[MAXN],*tail;Node *node[MAXN];int main(){    //freopen("in.txt","r",stdin);    //freopen("out.txt","w",stdout);    int T;    int iCase = 0;    int n,m;    scanf("%d",&T);    while(T--){        iCase++;        printf("Case #%d:\n",iCase);        scanf("%d%d",&n,&m);        tail = pool;        null = tail++;        null->fa = null->ch[0] = null->ch[1] = null;        null->size = null->rev = 0;        null->same = -INF; null->add = 0;        null->mm = null->sm = -INF;        null->mmc = null->smc = 0;        for(int i = 1;i <= n;i++){            int v ;            scanf("%d",&v);            node[i] = tail++;            node[i]->clear(v);        }        int u,v;        for(int i = 1;i < n;i++){            scanf("%d%d",&u,&v);            node[u]->link(node[v]);        }        int op;        int x,y,a,b;        while(m--){            scanf("%d",&op);            if(op == 1){                scanf("%d%d%d%d",&x,&y,&a,&b);                node[x]->cut(node[y]);                node[a]->link(node[b]);            }            else if(op == 2){                scanf("%d%d%d",&a,&b,&x);                SAME(node[a],node[b],x);            }            else if(op == 3){                scanf("%d%d%d",&a,&b,&x);                ADD(node[a],node[b],x);            }            else{                scanf("%d%d",&a,&b);                ask(node[a],node[b]);                if(SM == -INF)                    printf("ALL SAME\n");                else printf("%d %d\n",SM,SMC);            }        }    }    return 0;}


0 0