• AcWing 265. 营业额统计


    题目传送门

    #include <bits/stdc++.h>
    using namespace std;
    typedef long long LL;
    const int N = 33010;
    const int INF = 0x3f3f3f3f;
    
    int n;
    struct Node {
        int l, r;
        int key, val;
        int cnt;
        int size;
    } tr[N];
    
    int root, idx;
    void pushup(int p) {
        tr[p].size = tr[tr[p].l].size + tr[tr[p].r].size + tr[p].cnt;
    }
    int newnode(int key) {
        tr[++idx].key = key;
        tr[idx].val = rand();
        tr[idx].cnt = tr[idx].size = 1;
        return idx;
    }
    
    void zig(int &p) {
        int q = tr[p].l;
        tr[p].l = tr[q].r;
        tr[q].r = p;
        p = q;
        pushup(tr[p].r);
        pushup(p);
    }
    void zag(int &p) {
        int q = tr[p].r;
        tr[p].r = tr[q].l;
        tr[q].l = p;
        p = q;
        pushup(tr[p].l);
        pushup(p);
    }
    
    void build() {
        newnode(-INF), newnode(INF);
        root = 1, tr[1].r = 2;
        pushup(root);
        if (tr[1].val < tr[2].val) zag(root);
    }
    
    void insert(int &p, int key) {
        if (!p)
            p = newnode(key);
        else {
            if (tr[p].key == key)
                tr[p].cnt++;
            else {
                if (tr[p].key > key) {
                    insert(tr[p].l, key);
                    if (tr[tr[p].l].val > tr[p].val) zig(p);
                } else {
                    insert(tr[p].r, key);
                    if (tr[tr[p].r].val > tr[p].val) zag(p);
                }
            }
        }
        pushup(p);
    }
    // 注意这里与AcWing 253在细节上的区别,那个是严格小于key的最大数
    // 找到小于等于key的最大数
    int get_prev(int p, int key) {
        if (!p) return -INF;
        if (tr[p].key > key) return get_prev(tr[p].l, key);
        return max(tr[p].key, get_prev(tr[p].r, key));
    }
    
    // 注意这里与AcWing 253在细节上的区别,那个是严格大于key的最小数
    // 找到大于等于key的最小数
    int get_next(int p, int key) {
        if (!p) return INF;
        if (tr[p].key < key) return get_next(tr[p].r, key);
        return min(tr[p].key, get_next(tr[p].l, key));
    }
    
    int main() {
        //构建Treap
        build();
    
        scanf("%d", &n);
        LL res = 0;
        for (int i = 1; i <= n; i++) {
            int x;
            scanf("%d", &x);
            if (i == 1)
                res += x;
            else
                res += min(x - get_prev(root, x), get_next(root, x) - x);
            //一边统计一边加入
            insert(root, x);
        }
        //结果
        printf("%lld\n", res);
        return 0;
    }
    
  • 相关阅读:
    居敬持志
    测试内容
    TestMarkDown
    git
    面试题
    兼容的可视区高度和宽度
    JS(数据类型、预解析、闭包、作用域、this)
    JavaScript new 一个构造函数
    Windows下gm打水印老是报gm convert: Unable to read font (n019003l.pfb)问题
    如何开始一个vue+webpack项目
  • 原文地址:https://www.cnblogs.com/littlehb/p/16243062.html
Copyright © 2020-2023  润新知