NOI 郁闷的出纳员 (Spay树、平衡树操作)

来源:互联网 发布:淘宝热搜关键词 编辑:程序博客网 时间:2024/04/27 03:49

NOI 郁闷的出纳员 (Spay树、平衡树操作)

插入、删除所有小于p值的节点、k值

注意:可能有相同节点,所以用cnt[]记录

#pragma comment(linker, "/STACK:102400000000,102400000000")#include <cstdio>#include <ctime>#include <cstdlib>#include <cstring>#include <queue>#include <string>#include <set>#include <stack>#include <map>#include <cmath>#include <vector>#include <iostream>#include <algorithm>#include <bitset>using namespace std;//LOOP#define FF(i, a, b) for(int i = (a); i < (b); ++i)#define FE(i, a, b) for(int i = (a); i <= (b); ++i)#define FED(i, b, a) for(int i = (b); i>= (a); --i)#define REP(i, N) for(int i = 0; i < (N); ++i)#define CLR(A,value) memset(A,value,sizeof(A))//INPUT#define RI(n) scanf("%d", &n)#define RII(n, m) scanf("%d%d", &n, &m)#define RIII(n, m, k) scanf("%d%d%d", &n, &m, &k)typedef long long LL;typedef vector <int> VI;const int INF = 0x3f3f3f3f;const double eps = 1e-10;const int maxn = 211111;#define ll ch[x][0]#define rr ch[x][1]#define KT (ch[ch[rt][1]][0])int del_cnt;struct SplayStree{    int ch[maxn][2];    int pre[maxn], sz[maxn], cnt[maxn];    int val[maxn];    int rt, tot;    void up(int x)    {        sz[x] = sz[ll] + sz[rr] + cnt[x];///!!!    }    void Rotate(int x, int f)    {        int y = pre[x];//        down(y); down(x);///        ch[y][!f] = ch[x][f];        pre[ch[x][f]] = y;        pre[x] = pre[y];        if (pre[x]) ch[pre[y]][ch[pre[y]][1] == y] = x;        ch[x][f] = y;        pre[y] = x;        up(y);///    }    void Splay(int x, int goal)    {//        down(x);///        while (pre[x] != goal)        {            if (pre[pre[x]] == goal) Rotate(x, ch[pre[x]][0] == x);            else            {                int y = pre[x], z = pre[y];                int f = ( ch[z][0] == y );                if (ch[y][f] == x) Rotate(x, !f), Rotate(x, f);                else Rotate(y, f), Rotate(x, f);            }        }        up(x);///        if (goal == 0) rt = x;    }    void Init()    {        ch[0][0] = ch[0][1] = pre[0] = 0;        val[0] = sz[0] = 0;        rt = tot = 0;    }    void Newnode(int &x, int v, int f)    {        x = ++tot;        ll = rr = 0; pre[x] = f;        val[x] = v; sz[x] = cnt[x] = 1;    }    void Insert(int &x, int v, int f)    {        if (!x)        {            Newnode(x, v, f); Splay(x, 0); return ;        }        else if (val[x] == v)        {            cnt[x]++; sz[x]++;            Splay(x, 0); return;        }        else if (val[x] > v) Insert(ll, v, x);        else Insert(rr, v, x);        up(x);    }    void Delete(int &x, int v, int f)    {        if (!x) return ;        if (val[x] < v)        {            del_cnt += sz[ll] + cnt[x];            x = rr;            pre[x] = f;            Delete(x, v, f);            if (!f) rt = x;///!!!        }        else Delete(ll, v, x);        if (x) up(x);    }    int kth(int x, int k)    {//        int ss = sz[rr] + cnt[x];        if (k <= sz[rr]) return kth(rr, k);        else if (k > sz[rr] + cnt[x]) return kth(ll, k - sz[rr] - cnt[x]);        else        {            Splay(x, 0);            return val[x];        }    }}sp;int main(){    int n, m, k;    int limit, li;    li = 0;    del_cnt = 0;    char op[5];    scanf("%d%d", &n, &limit);    sp.Init();    while (n--)    {        scanf("%s%d", op, &k);        if (op[0] == 'I')        {            if (k >= limit)                sp.Insert(sp.rt, k - li, 0);        }        else if (op[0] == 'A')            li += k;        else if (op[0] == 'S')        {            li -= k;            if (sp.sz[sp.rt] > 0)                sp.Delete(sp.rt, limit - li, 0);        }        else        {            if (k <= 0 || k > sp.sz[sp.rt]) printf("-1\n");            else printf("%d\n", sp.kth(sp.rt, k) + li);        }//        cout << "sz: " << sp.val[sp.rt] << ' ' << sp.sz[sp.rt] << endl;    }    printf("%d\n", del_cnt);    return 0;}


原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 tst优惠码密码忘了怎么办 扩展器登录不上怎么办 微信学法小程序积分不更新怎么办 开发商不给办房产证怎么办 传淘宝产品规格不匹配怎么办 刚买的手机想退怎么办 空调主机空间不足不散热怎么办 lol网速快延迟高怎么办 4g手机延迟高怎么办 天气冷鼻炎就犯怎么办 天气冷宝宝发烧了怎么办 wp手机开机忘记了密码怎么办 微商退货不退款怎么办 微商退货了不退款怎么办 微商退货后不退款怎么办 有赞买东西付款没发货怎么办 赞礼号掉了东西怎么办 万达贷系统维护还不了款怎么办 qq文件发不出去怎么办 1688分销没有传淘宝怎么办 京东的货运代理怎么办 天天练推广期没了怎么办 微信自动建群怎么办 刚刚不小心扫了无痕爆客怎么办 苹果6升级卡死怎么办 随行付换手机了怎么办 融e联账号冻结怎么办 58同城高危账户怎么办 网购迟迟不发货怎么办 优酷不能投屏了怎么办 爱尚街借款不还怎么办 小米商城买东西没收到货怎么办 微信投票地区限制怎么办 微信退款未到账怎么办 微信钱包锁忘了怎么办 xp系统管理员密码忘了怎么办 沃尔沃menu键没反应怎么办 微信转账受限制怎么办 被米虎网骗了手里还有合同怎么办 学校要求上传论文pdf格式怎么办 备份的Wifi密码查看乱码怎么办