To the moon
题目链接: To the moon HDU - 4348
题意
给你长度为n的数组,共有四个操作:
•1.对区间【L,R】增加d,并时间增加1
•2.询问当前时间的区间【L,R】的和
•3.询问时间为T时的区间【L,R】的和
•4.返回到时间为T的时候
思路
既然有着时间点的要求也就是历史版本的要求,那么主席树肯定是没跑的了,奈何我没有合适的模板,那么这道题,就是我主席树的模板了吧。还有但是主席树的区间的修改,一种办法是在遇到有延迟更新的区间的时候重新开左右儿子来pushdown 标记,但是这题严格一点的数据就能把他卡成空间为n*n*logn。所以还有一种办法就是,永久化标记,不pushdown,这时候就可以大大节省空间了,nlogn的空间复杂度。
代码
#include <bits/stdc++.h>
using namespace std;
#define rep(i,j,k) for(int i = (int)j;i <= (int)k;i ++)
#define per(i,j,k) for(int i = (int)j;i >= (int)k;i --)
#define debug(x) cerr<<#x<<" = "<<(x)<<endl
#define mmm(a,b) memset(a,b,sizeof(a))
#define pb push_back
typedef double db;
typedef long long ll;
const int MAXN = (int)1e5+7;
const int INF = (int)0x3f3f3f3f;
int root[MAXN