题目描述

给定一段长度为 \(N\) 的序列 \(a\) 以及 \(M\) 次操作,操作有以下几种:

  • C l r d :将区间 \([l,r]\) 中的数都加上 \(d\)
  • Q l r :查询当前时间戳区间 \([l,r]\) 中所有数的和
  • H l r t :查询时间戳为 \(t\) 时,区间 \([l,r]\) 中所有数的和
  • B t :将当前时间戳重置为 \(t\)

对于每一次询问操作,输出一行对应的答案。

时间戳初始值为 \(0\)

数据范围:

\(1\leq N,M\leq 10^5\)

然后要开 long long


基本思路

主席树的一道比较模板的题。。。

原谅我不想讲细节(其实代码里面写的还可以)

关于标记永久化的一些实现细节,我是参考的《信息学奥赛一本通 \(\cdot\) 提高篇》


细节注意事项

  • long long一定要开
  • 细节不要写挂,数据结构题还是有难调的
  • 应该不会有人像我一样搞错输入顺序吧。。。

参考代码

/*--------------------------------
Author: The Ace Bee
Blog: www.cnblogs.com/zsbzsb
This code is made by The Ace Bee
--------------------------------*/
#include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#include <cctype>
#include <cmath>
#include <ctime>
#define rg register
using namespace std;
template < typename T > inline void read(T& s) {
s = 0; int f = 0; char c = getchar();
while (!isdigit(c)) f |= (c == '-'), c = getchar();
while (isdigit(c)) s = s * 10 + (c ^ 48), c = getchar();
s = f ? -s : s;
} typedef long long LL;
const int _ = 100010; int n, m, a[_];
int tot, rt[_], lc[_ << 5], rc[_ << 5];
LL sum[_ << 5], add[_ << 5]; inline void build(int& p, int l = 1, int r = n) {
p = ++tot;
if (l == r) return read(sum[p]);
int mid = (l + r) >> 1;
build(lc[p], l, mid), build(rc[p], mid + 1, r);
sum[p] = sum[lc[p]] + sum[rc[p]];
} inline void update(int& p, int q, int ql, int qr, int v, int l = 1, int r = n) {
lc[p = ++tot] = lc[q], rc[p] = rc[q], add[p] = add[q], sum[p] = sum[q];
if (ql <= l && r <= qr) { add[p] += v; return; }
int mid = (l + r) >> 1;
if (ql <= mid) update(lc[p], lc[q], ql, qr, v, l, mid);
if (qr > mid) update(rc[p], rc[q], ql, qr, v, mid + 1, r);
sum[p] += 1ll * v * (min(qr, r) - max(ql, l) + 1);
} inline LL query(int p, int ql, int qr, int l = 1, int r = n) {
if (ql <= l && r <= qr) return sum[p] + 1ll * add[p] * (r - l + 1);
int mid = (l + r) >> 1; LL res = 0;
if (ql <= mid) res += query(lc[p], ql, qr, l, mid);
if (qr > mid) res += query(rc[p], ql, qr, mid + 1, r);
return res + 1ll * add[p] * (min(qr, r) - max(ql, l) + 1);
} int main() {
#ifndef ONLINE_JUDGE
freopen("in.in", "r", stdin);
#endif
read(n), read(m), build(rt[0]);
int tim = 0;
for (rg int i = 1; i <= m; ++i) {
char s[5]; scanf("%s", s);
if (s[0] == 'B') read(tim), tot = rt[tim + 1] - 1;
else if (s[0] == 'C') { int ql, qr, v;
read(ql), read(qr), read(v), ++tim;
update(rt[tim], rt[tim - 1], ql, qr, v);
} else if (s[0] == 'Q') { int ql, qr;
read(ql), read(qr);
printf("%lld\n", query(rt[tim], ql, qr));
} else if (s[0] == 'H') { int t, ql, qr;
read(ql), read(qr), read(t);
printf("%lld\n", query(rt[t], ql, qr));
}
}
return 0;
}

「SP11470」TTM - To the moon的更多相关文章

  1. SP11470 TTM - To the moon[主席树标记永久化]

    SP11470 TTM - To the moon C l r d:区间 \([L,R]\) 中的数都加 d ,同时当前的时间戳加 1. Q l r:查询当前时间戳区间 \([L,R]\) 中所有数的 ...

  2. 「译」JUnit 5 系列:条件测试

    原文地址:http://blog.codefx.org/libraries/junit-5-conditions/ 原文日期:08, May, 2016 译文首发:Linesh 的博客:「译」JUni ...

  3. 「译」JUnit 5 系列:扩展模型(Extension Model)

    原文地址:http://blog.codefx.org/design/architecture/junit-5-extension-model/ 原文日期:11, Apr, 2016 译文首发:Lin ...

  4. JavaScript OOP 之「创建对象」

    工厂模式 工厂模式是软件工程领域一种广为人知的设计模式,这种模式抽象了创建具体对象的过程.工厂模式虽然解决了创建多个相似对象的问题,但却没有解决对象识别的问题. function createPers ...

  5. 「C++」理解智能指针

    维基百科上面对于「智能指针」是这样描述的: 智能指针(英语:Smart pointer)是一种抽象的数据类型.在程序设计中,它通常是经由类型模板(class template)来实做,借由模板(tem ...

  6. 「JavaScript」四种跨域方式详解

    超详细并且带 Demo 的 JavaScript 跨域指南来了! 本文基于你了解 JavaScript 的同源策略,并且了解使用跨域跨域的理由. 1. JSONP 首先要介绍的跨域方法必然是 JSON ...

  7. 「2014-5-31」Z-Stack - Modification of Zigbee Device Object for better network access management

    写一份赏心悦目的工程文档,是很困难的事情.若想写得完善,不仅得用对工具(use the right tools),注重文笔,还得投入大把时间,真心是一件难度颇高的事情.但,若是真写好了,也是善莫大焉: ...

  8. 「2014-3-18」multi-pattern string match using aho-corasick

    我是擅(倾)长(向)把一篇文章写成杂文的.毕竟,写博客记录生活点滴,比不得发 paper,要求字斟句酌八股结构到位:风格偏杂文一点,也是没人拒稿的.这么说来,arxiv 就好比是 paper 世界的博 ...

  9. 「2014-3-17」C pointer again …

    记录一个比较基础的东东-- C 语言的指针,一直让人又爱又恨,爱它的人觉得它既灵活又强大,恨它的人觉得它太过于灵活太过于强大以至于容易将人绕晕.最早接触 C 语言,还是在刚进入大学的时候,算起来有好些 ...

随机推荐

  1. HDU1276-士兵队列训练问题 (Queue)

    题很简单,STL中queue的基本使用. #include <bits/stdc++.h> using namespace std; int N,num; int main() { sca ...

  2. Windows Server 2012R2 实现AD双域控制器互为冗余

    前言 在部署活动目录服务的时候,首先应该考虑域控制器的安全性,主域控一旦崩掉,一般很难修复,后果非常严重,本文介绍在活动目录中部署两台域控制器,两台都是主控,互为冗余. 环境网络192.168.100 ...

  3. Go语言内置包之strconv

    文章引用自 Go语言内置包之strconv Go语言中strconv包实现了基本数据类型和其字符串表示的相互转换. strconv包 strconv包实现了基本数据类型与其字符串表示的转换,主要有以下 ...

  4. emoji web端处理

    1.发送给服务器端的信息,因为图片是选择的在web端只提供了50个表情选择,所以将 #哈哈# ,凡是#  #包裹的内容转化成对应的unicode编码, 比如U+1F603.每一个对应起来,这一点比较麻 ...

  5. C语言:去除一个字符串中所有的空格。-函数fun传入形参m,求t=1/2-1/3+1/4.....+1/m的值。-判断形参a指定的矩阵是不是“幻方“。

    //函数fun功能:判断形参a指定的矩阵是不是“幻方“,若是返回1.(”幻方”:每列,每行,对角线,反对角线相加都相等) #include <stdio.h> #define N 3 in ...

  6. [linux] ARCH LINUX 常见问题及实用工具汇总

    1.办公 screen-recorder 1)深度linux桌面录制软件(不支持录音),操作简单,可以保存mp4和gif格式 2)命令安装:sudo pacman -S deepin-screen-r ...

  7. 「CF1142B」Lynyrd Skynyrd

    传送门 Luogu 解题思路 发现一个性质: 对于排列的任何一个循环位移,排列中的同一个数的前驱肯定是不变的. 而且,如果一个排列的循环位移是某一个区间的子序列,那么这个循环位移的结尾的 \(n-1\ ...

  8. go开发工具goclipse的安装

    (1) 安装Eclipse 建议下载Eclipse时直接下载"Eclipse IDE for Java Developers"的package,而不要下载较小的Installer. ...

  9. Java常用API——Arrays工具类

    介绍:Arrays工具类提供了一些可以直接操作数组的方法,以下是一些常用方法: int binarySearch(type[] a, type key):要求数组a元素升序排列,使用二分法搜索key的 ...

  10. 【渗透测试】Squirrelmail远程代码执行漏洞+修复方案

    最近网上有点不太平,爆出各种漏洞,等下会把近期的漏洞复现一下,发出来.安全圈的前辈总是默默的奉献,在这里晚辈们只能站在巨人的肩膀上,跟紧前辈们的步伐,走下去. -------------------- ...