题目传送门

sol:第一次看题还真信了是用线段树来做,但是没什么想法,看了题解发现是我不会的Treap,然后花了几天时间学习了一下并补掉题目

  • 无旋Treap

    #include <bits/stdc++.h>
    using namespace std;
    typedef long long LL;
    const int MAXN = 2e5 + ;
    struct Treap {
    int ls, rs;
    int rand, size;
    LL sum, val, lazy;
    } node[MAXN];
    int root, tot;
    int add_node(int v) {
    int i = ++tot;
    node[i].ls = node[i].rs = ;
    node[i].rand = rand();
    node[i].sum = node[i].val = v;
    node[i].lazy = ;
    node[i].size = ;
    return i;
    }
    void push_down(int rt) {
    int ls = node[rt].ls;
    int rs = node[rt].rs;
    if (ls != ) {
    node[ls].lazy += node[rt].lazy;
    node[ls].val += node[rt].lazy;
    node[ls].sum += node[ls].size * node[rt].lazy;
    }
    if (rs != ) {
    node[rs].lazy += node[rt].lazy;
    node[rs].val += node[rt].lazy;
    node[rs].sum += node[rs].size * node[rt].lazy;
    }
    node[rt].lazy = ;
    }
    void push_up(int rt) {
    int ls = node[rt].ls;
    int rs = node[rt].rs;
    node[rt].size = node[ls].size + node[rs].size + ;
    node[rt].sum = node[ls].sum + node[rs].sum + node[rt].val;
    }
    void split(int rt, int& a, int& b, int s) {
    if (rt == ) {
    a = b = ;
    return;
    }
    push_down(rt);
    int size = node[node[rt].ls].size;
    if (size < s) {
    a = rt;
    split(node[rt].rs, node[a].rs, b, s - size - );
    } else {
    b = rt;
    split(node[rt].ls, a, node[b].ls, s);
    }
    push_up(rt);
    }
    void merge(int& rt, int a, int b) {
    if (a == || b == ) {
    rt = a + b;
    return;
    }
    push_down(a);
    push_down(b);
    if (node[a].rand < node[b].rand) {
    rt = a;
    merge(node[rt].rs, node[a].rs, b);
    } else {
    rt = b;
    merge(node[rt].ls, a, node[b].ls);
    }
    push_up(rt);
    }
    void insert(int p, int v) {
    int x = , y = ;
    split(root, x, y, p - );
    merge(root, x, add_node(v));
    merge(root, root, y);
    }
    void add(int l, int r, int v) {
    int x = , y = , z = ;
    split(root, root, z, r);
    split(root, x, y, l - );
    node[y].lazy += v;
    node[y].val += v;
    node[y].sum += node[y].size * v;
    merge(root, x, y);
    merge(root, root, z);
    }
    LL query(int l, int r) {
    int x = , y = , z = ;
    split(root, root, z, r);
    split(root, x, y, l - );
    LL sum = node[y].sum;
    merge(root, x, y);
    merge(root, root, z);
    return sum;
    }
    int main() {
    int n, q;
    scanf("%d", &n);
    for (int i = ; i <= n; i++) {
    int v; scanf("%d", &v);
    merge(root, root, add_node(v));
    }
    scanf("%d", &q);
    for (int i = ; i <= q; i++) {
    int opt; scanf("%d", &opt);
    if (opt == ) {
    int pos; scanf("%d", &pos);
    insert(pos, );
    } else if (opt == ) {
    int l, r, v;
    scanf("%d%d%d", &l, &r, &v);
    add(l, r, v);
    } else {
    int l, r;
    scanf("%d%d", &l, &r);
    printf("%lld\n", query(l, r));
    }
    }
    return ;
    }

    在前置知识都掌握的情况下Treap还是挺好懂的,而且之前感觉lazy标记挺乱的,看了这题之后感觉理清了

牛客-Forsaken的数列(Treap)的更多相关文章

  1. 牛客 Rabbit的数列 (线段树维护值为x的个数+区间覆盖)

    https://ac.nowcoder.com/acm/contest/907/C 链接:https://ac.nowcoder.com/acm/contest/907/C来源:牛客网 题目描述 Ra ...

  2. C数列下标 牛客OI赛制测试赛2

    链接:https://www.nowcoder.com/acm/contest/185/C来源:牛客网 给出一个数列 A,求出一个数列B. 其中Bi   表示 数列A中 Ai 右边第一个比 Ai 大的 ...

  3. 牛客小白月赛18 Forsaken给学生分组

    牛客小白月赛18 Forsaken给学生分组 Forsaken给学生分组 链接:https://ac.nowcoder.com/acm/contest/1221/C来源:牛客网 ​ Forsaken有 ...

  4. 牛客小白月赛18 Forsaken喜欢数论

    牛客小白月赛18 Forsaken喜欢数论 题目传送门直接点标题 ​ Forsaken有一个有趣的数论函数.对于任意一个数xxx,f(x)f(x)f(x)会返回xxx的最小质因子.如果这个数没有最小质 ...

  5. 牛客多校第九场 && ZOJ3774 The power of Fibonacci(二次剩余定理+斐波那契数列通项/循环节)题解

    题意1.1: 求\(\sum_{i=1}^n Fib^m\mod 1e9+9\),\(n\in[1, 1e9], m\in[1, 1e4]\) 思路1.1 我们首先需要知道斐波那契数列的通项是:\(F ...

  6. 斐波那契数列 牛客网 剑指Offer

    斐波那契数列 牛客网 剑指Offer 题目描述 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0). n<=39 class Solution: ...

  7. 最大连续数列和 牛客网 程序员面试金典 C++ Python

    最大连续数列和 牛客网 程序员面试金典 C++ Python 题目描述 对于一个有正有负的整数数组,请找出总和最大的连续数列. 给定一个int数组A和数组大小n,请返回最大的连续数列的和.保证n的大小 ...

  8. 2018牛客网暑期ACM多校训练营(第一场)B Symmetric Matrix(思维+数列递推)

    题意 给出一个矩阵,矩阵每行的和必须为2,且是一个主对称矩阵.问你大小为n的这样的合法矩阵有多少个. 分析 作者:美食不可负064链接:https://www.nowcoder.com/discuss ...

  9. 关于斐波那契数列的一些恒等式 模板 牛客OI测试赛 A 斐波拉契

    牛客A 斐波拉契 链接:https://www.nowcoder.com/acm/contest/181/A来源:牛客网 设f[i]表示斐波那契数论的第i项 f[1]=1,f[2] =1,f[i] = ...

随机推荐

  1. Linq------连表查询

    1 List<Student> list = new List<Student>() { ,sex="男"}, ,sex="男"}, , ...

  2. Java程序员想年后跳槽,对JVM没有深入的理解,我劝你还是别跳了

    前言 Java 虚拟机是学习 Java 的基础,也是迈入高级 Java 开发工程师的必备知识点.所以今天这篇文章我们来聊聊如何从零开始学习 Java 虚拟机. 深入浅出Java虚拟机 对于刚刚接触 J ...

  3. vue项目准备2

    单文件组件与路由 .vue结尾的文件都是单文件组件 路由就是根据网址的不同返回的页面不同 多页应用与单页应用 多页应用: 每次页面跳转,服务器都会返回一个html. 优点:首次展现页面快.搜索引擎排名 ...

  4. 【论文笔记系列】AutoML:A Survey of State-of-the-art (下)

    [论文笔记系列]AutoML:A Survey of State-of-the-art (上) 上一篇文章介绍了Data preparation,Feature Engineering,Model S ...

  5. POJ - 1061 扩展欧几里德算法+求最小正整数解

    //#pragma comment(linker, "/STACK:1024000000,1024000000") //#pragma GCC optimize(2) #inclu ...

  6. flutter依赖某些插件,点击运行会出现错误

    org.gradle.jvmargs=-Xmx1536M android.useAndroidX=true android.enableJetifier=true android.enableAapt ...

  7. Win 10 Ctrl + Space 冲突

    1. 说明 在IDE里面Ctrl + space 会与 Windows 输入法相互冲突,并且用Ctrl + Space 切换中英文也很不常用(常用直接shift切换). 2. 操作 控制面板——时钟. ...

  8. 编程基础-servlet1

    1.Servelet是什么 sevlet是Server与Applet 的缩写,即服务端小程序.Sun公司提供的开发动态web资源的技术. servelet本质是java类,但遵循Servlet规范,没 ...

  9. 题解【[BJOI2015]树的同构】

    切了省选题+紫题,来写个题解 这题其实挺水,才120行代码 该题写了我一天(上午1.5h,晚上10min = 一天) hash,对于节点A,\[hashval[A] = \{hashval[i]\ti ...

  10. 5314跳跃游戏IV

    题目:给你一个整数数组 arr ,你一开始在数组的第一个元素处(下标为 0).每一步,你可以从下标 i 跳到下标:    i + 1 满足:i + 1 < arr.length    i - 1 ...