Codeforces 85D Sum of Medians(线段树)[通俗易懂]

Codeforces 85D Sum of Medians(线段树)

大家好,又见面了,我是全栈君。

题目链接:Codeforces 85D – Sum of Medians

题目大意:N个操作,add x:向集合中加入x;del x:删除集合中的x;sum:将集合排序后,将集合中全部下标i % 5 = 3的元素累加求和。

解题思路:线段树单点更新,每一个点维护5个值。分别表示从该段区间中i % 5 = t的和。然后两端区间合并时仅仅须要依据左孩子中元素的个数合并。所以有一个c表示区间上元素的个数。

由于有同样的数。所以要离线操做,将全部的数映射成位置,可是对于del则不须要映射,由于集合中肯定有才干减掉。那么add和sum操作都是能够搞定了,仅仅剩下del操作,对于del x,x肯定在集合中出现过。所以每次删除第一个x就可以,假设高速查找,要借助map和一个辅助数组,由于删除一个后要又一次映射,所以借助辅助数组。

#include <cstdio>
#include <cstring>
#include <map>
#include <vector>
#include <algorithm>

using namespace std;

typedef long long ll;
const int mod = 5;
const int maxn = 1e5+5;

int N, M, pos[maxn], v[maxn];
map<ll, int> G;

#define lson(x) ((x)<<1)
#define rson(x) (((x)<<1)|1)
int lc[maxn << 2], rc[maxn << 2], c[maxn << 2];
ll s[maxn << 2][6];

inline void maintain (int u, int d) {
    c[u] += d;
    memset(s[u], 0, sizeof(s[u]));
    s[u][0] = (c[u] ? pos[lc[u]] : 0);
}

inline void pushup(int u) {
    int t = c[lson(u)] % mod;
    c[u] = c[lson(u)] + c[rson(u)];
    for (int i = 0; i < mod; i++)
        s[u][i] = s[lson(u)][i] + s[rson(u)][(i + mod - t) % mod];
}

void build (int u, int l, int r) {
    lc[u] = l;
    rc[u] = r;
    c[u] = 0;
    memset(s[u], 0, sizeof(s[u]));

    if (l == r)
        return;
    int mid = (l + r) / 2;
    build(lson(u), l, mid);
    build(rson(u), mid + 1, r);
    pushup(u);
}

void modify (int u, int x, int d) {
    if (lc[u] == x && rc[u] == x) {
        maintain(u, d);
        return;
    }

    int mid = (lc[u] + rc[u]) / 2;
    if (x <= mid)
        modify(lson(u), x, d);
    else
        modify(rson(u), x, d);
    pushup(u);
}

struct OP {
    int p, k, id;
    OP (int k = 0, int p = 0, int id = 0) {
        this->k = k;
        this->p = p;
        this->id = id;
    }
    friend bool operator < (const OP& a, const OP& b) {
        if (a.k == 0)
            return false;
        if (b.k == 0)
            return true;
        if (a.p != b.p)
            return a.p < b.p;
        return a.id < b.id;
    }
};

inline bool cmp (const OP& a, const OP& b) {
    return a.id < b.id;
}

vector<OP> vec;

void init () {
    scanf("%d", &N);
    char op[5];
    int x;

    for (int i = 1; i <= N; i++) {
        scanf("%s", op);
        if (op[0] == 's')
            vec.push_back(OP(0, 0, i));
        else {
            scanf("%d", &x);
            vec.push_back(OP(op[0] == 'a' ? 1 : -1, x, i));
        }
    }

    M = 1;
    sort(vec.begin(), vec.end());
    for (int i = 0; i < N; i++) {
        if (vec[i].k < 0)
            continue;
        if (vec[i].k == 0)
            break;

        pos[M] = vec[i].p;
        vec[i].p = M++;
    }
    build(1, 1, M);
}

void solve () {
    sort(vec.begin(), vec.end(), cmp);
    for (int i = 0; i < N; i++) {
        //printf("%d %d!\n", vec[i].k, pos[vec[i].p]);
        if (vec[i].k == 0)
            printf("%lld\n", s[1][2]);
        else if (vec[i].k == -1) {
            int tmp = vec[i].p;
            v[G[tmp]] = 0;
            modify(1, G[tmp], -1);

            if (G[tmp] <= N && v[G[tmp]+1] && pos[G[tmp]] == pos[G[tmp]+1])
                G[tmp]++;
            else
                G[tmp] = 0;
        } else {
            int tmp = pos[vec[i].p];
            v[vec[i].p] = 1;
            modify(1, vec[i].p, 1);
            if (G[tmp] == 0)
                G[tmp] = vec[i].p;
        }
    }
}

int main () {
    init();
    solve();
    return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116117.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • mybatis缓存配置

    mybatis缓存配置mybatis的缓存有三种方式:1、一级缓存(基于SqlSession会话级别的;2、二级缓存(基于nameSpace级别的,范围比以及缓存更广);3、第三方缓存;mybatis缓存使示意图:一、一级缓存说明:其中一级缓存是mybatis默认使用的缓存,无需手动配置,二级缓存需要手动配置;一级缓存失效条件1)sqlSession不同,由于一级缓存是基于sqlSession级别的,所以当使用不同sq…

    2022年5月21日
    118
  • 设计模式、框架、架构、平台的区别「建议收藏」

    设计模式、框架、架构、平台的区别「建议收藏」区分什么是架构、框架、模式和平台,一直都感觉这几个词过于抽象和模糊,今天大家来说说到底什么是架构、框架、模式和平台? 收集了的一些来自网上各自的定义和区分如下: 设计模式 1、设计模式为什么要先说设计模式?因为设计模式在这些概念中是最基本的,而且也比较简单。那么什么是设计模式呢?说的直白点,设计模式就是告诉你针对特定问题如何组织类、对象和接口之间的关系,是前人总结的经验

    2022年10月10日
    3
  • ❤️肝下25万字的《决战Linux到精通》笔记,你的Linux水平将从入门到入魔❤️【建议收藏】

    ❤️肝下25万字的《决战Linux到精通》笔记,你的Linux水平将从入门到入魔❤️【建议收藏】文章目录操作系统的发展史UnixMinixLinux操作系统的发展Minix没有火起来的原因Linux介绍Linux内核&发行版Linux内核版本Linux发行版本类Unix系统目录结构Linux目录用户目录命令行基本操作命令使用方法查看帮助文档helpman(manual)tab键自动补全history游览历史命令行中的ctrl组合键Linux命令权限管理列出目录的内容:ls显示inode的内容:stat文件访问权限修改文件权限:chmod修改文件所有者:chown修改文件所属组:chgrp文件.

    2022年6月1日
    28
  • 勾勒Tor的全球使用情况

    勾勒Tor的全球使用情况

    2022年3月6日
    39
  • 计算机教育中缺失的一课,劝学弟学妹们一句,一定要趁早补上,工作后会事半功倍!「建议收藏」

    计算机教育中缺失的一课,劝学弟学妹们一句,一定要趁早补上,工作后会事半功倍!「建议收藏」各位学弟学妹们好,作为稍微年长的我(岁月是把杀猪刀啊),今天就给大家补补课。在大学里的,我们上的计算机专业课程一般都是像操作系统、编译原理、计算机组成原理、计算机网络这些理论课程,还有一些像C语言、Java、.Net这些可以实践的课程,甚至还有可能让你焊一个收音机,但是对于一些基本习惯却很容易被忽略,需要学弟学妹们自行摸索。实际上,一些好的基本习惯是时时刻刻在影响着我们自己的,不仅是在学校的学习生活中,还是在毕业后的工作生活中。今天我要给大家说就是,使用键盘的习惯。有的同学可能会诧异,键盘谁不会用啊,

    2022年7月16日
    25
  • DM368开发 — 毕设之硬件[通俗易懂]

    DM368开发 — 毕设之硬件[通俗易懂]这部分将参看相关的毕业论文设计来讲一下DM368的硬件部分。参看:相关论文基于DM368的高清视频监控系统设计与实现–文波一、系统硬件电路详细设计3.1TMS320DM368硬件平台简介TMS320DM368是德州仪器公司(TI)于2010年4月推出的新一代基于Davinci技术的高清视频处理器,内部集成了一颗ARM内核和两个视频图像协处理器,同时内部还集成了一个视频

    2022年8月13日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号