共有Q个更新,每次更新给更新的区间一个标记,表示该区间是在哪一次被更新,最后统计答案是以最近被更新的值为答案。
如有不当之处欢迎指出!
AC代码:
#include<cstdio>
const int maxn=8e5+5;
struct node{
int num,val;
}tree[maxn];
int num,val;
void Build(int l,int r,int ll,int rr,int cur){
if(l==ll&&r==rr){
tree[cur].num=num;
tree[cur].val=val;
return;
}
int mid=(ll+rr)/2;
if(r<=mid) Build(l,r,ll,mid,cur<<1);
else if(l>=mid+1) Build(l,r,mid+1,rr,(cur<<1)+1);
else {
Build(l,mid,ll,mid,cur<<1);
Build(mid+1,r,mid+1,rr,(cur<<1)+1);
}
}
int n,c=0,w=0;
void print(int l,int r,int cur,int ans,int u){
if(tree[cur].num>=u){
u=tree[cur].num;
ans=tree[cur].val;
}
if(l==r){
++c;
w+=ans;
return;
}
print(l,(l+r)/2,cur<<1,ans,u);
print((l+r)/2+1,r,(cur<<1)+1,ans,u);
}
int main(){
int T,Q,kase=1;
scanf("%d",&T);
while(T--){
w=0;
for(int i=0;i<maxn;++i) {
tree[i].val=1;
tree[i].num=0;
}
scanf("%d%d",&n,&Q);
int a,b;
for(int i=0;i<Q;++i){
scanf("%d%d%d",&a,&b,&val);
num=i+1;
Build(a,b,1,n,1);
}
print(1,n,1,0,0);
printf("Case %d: The total value of the hook is %d.\n",kase++,w);
}
return 0;
}
如有不当之处欢迎指出!