线段树练习3
来源:互联网 发布:淘宝美工素材 编辑:程序博客网 时间:2024/04/29 22:04
#include<iostream>
#include<cstdio>
using namespace std;
const long long maxn=10000000;
long long a[maxn]={0};
struct node
{
long long left,right,num,lazy;
}f[maxn];
void build(long long k,long long s,long long t)
{
long long mid=(s+t)/2;
f[k].left=s;f[k].right=t;
if(s==t){f[k].num=a[s];return ;}
else
{
build(k*2,s,mid);
build(k*2+1,mid+1,t);
f[k].num=f[k*2].num+f[k*2+1].num;
}
}
void push(long long k,long long l)
{
f[k*2].lazy+=f[k].lazy;
f[k*2+1].lazy+=f[k].lazy;
f[k*2].num+=(l-l/2)*f[k].lazy;
f[k*2+1].num+=(l/2)*f[k].lazy;
f[k].lazy=0;
}
long long tt=0;
void ins(long long k,long long a,long long b,long long x)
{
// tt++;
long long l=f[k].left,r=f[k].right;
if(a==l&&b==r)
{
f[k].lazy+=x;
f[k].num+=(b-a+1)*x;
return ;
}
if(f[k].lazy)push(k,r-l+1);
long long mid=(l+r)/2;
if(b<=mid)ins(k*2,a,b,x);
else if(a>mid)ins(k*2+1,a,b,x);
else
{ins(k*2,a,mid,x);
ins(k*2+1,mid+1,b,x);}
f[k].num=f[k*2].num+f[k*2+1].num;
}
long long cont(long long k,long long a,long long b)
{
long long l=f[k].left,r=f[k].right;
if(l==a&&r==b){return f[k].num;}
if(f[k].lazy){push(k,r-l+1);}
long long mid=(l+r)/2;
if(b<=mid){return cont(k*2,a,b);}
else if(a>mid){return cont(k*2+1,a,b);}
else{
return cont(k*2,a,mid)+cont(k*2+1,mid+1,b);}
}
int main()
{
long long n,m;
cin>>n;
for(long long i=1;i<=n;i++)
cin>>a[i];
build (1,1,n);
cin>>m;
long long t,k,x,y;
for(long long i=1;i<=m;i++)
{ cin>>t;
if(t==1){cin>>x>>y>>k;ins(1,x,y,k);
}
else
{cin>>x>>y;
cout<<cont(1,x,y)<<endl;
}
}
//cout<<tt;
// while(1);
}
#include<cstdio>
using namespace std;
const long long maxn=10000000;
long long a[maxn]={0};
struct node
{
long long left,right,num,lazy;
}f[maxn];
void build(long long k,long long s,long long t)
{
long long mid=(s+t)/2;
f[k].left=s;f[k].right=t;
if(s==t){f[k].num=a[s];return ;}
else
{
build(k*2,s,mid);
build(k*2+1,mid+1,t);
f[k].num=f[k*2].num+f[k*2+1].num;
}
}
void push(long long k,long long l)
{
f[k*2].lazy+=f[k].lazy;
f[k*2+1].lazy+=f[k].lazy;
f[k*2].num+=(l-l/2)*f[k].lazy;
f[k*2+1].num+=(l/2)*f[k].lazy;
f[k].lazy=0;
}
long long tt=0;
void ins(long long k,long long a,long long b,long long x)
{
// tt++;
long long l=f[k].left,r=f[k].right;
if(a==l&&b==r)
{
f[k].lazy+=x;
f[k].num+=(b-a+1)*x;
return ;
}
if(f[k].lazy)push(k,r-l+1);
long long mid=(l+r)/2;
if(b<=mid)ins(k*2,a,b,x);
else if(a>mid)ins(k*2+1,a,b,x);
else
{ins(k*2,a,mid,x);
ins(k*2+1,mid+1,b,x);}
f[k].num=f[k*2].num+f[k*2+1].num;
}
long long cont(long long k,long long a,long long b)
{
long long l=f[k].left,r=f[k].right;
if(l==a&&r==b){return f[k].num;}
if(f[k].lazy){push(k,r-l+1);}
long long mid=(l+r)/2;
if(b<=mid){return cont(k*2,a,b);}
else if(a>mid){return cont(k*2+1,a,b);}
else{
return cont(k*2,a,mid)+cont(k*2+1,mid+1,b);}
}
int main()
{
long long n,m;
cin>>n;
for(long long i=1;i<=n;i++)
cin>>a[i];
build (1,1,n);
cin>>m;
long long t,k,x,y;
for(long long i=1;i<=m;i++)
{ cin>>t;
if(t==1){cin>>x>>y>>k;ins(1,x,y,k);
}
else
{cin>>x>>y;
cout<<cont(1,x,y)<<endl;
}
}
//cout<<tt;
// while(1);
}
0 0
- 线段树练习3
- 线段树练习3
- 线段树练习3
- Codevs_P1082 线段树练习3(线段树)
- 【wikioi1082】 线段树练习 3
- wikioi1082【线段树练习 3 】
- codevs1082 线段树练习3
- 【codevs1082】线段树练习 3
- codevs线段树练习3
- [CODEVS1082]线段树练习 3
- <线段树系列3> codevs 1082 线段树练习3
- codevs1082线段树练习3(线段树)
- 【Codevs】1082 线段树练习 3 && 线段树模板
- Codevs 1082 线段树练习 3(线段树&&分块)
- 【线段树+lazy优化】1082线段树练习3
- wikioi 1082 线段树练习 3
- Code Vs 1082 线段树练习 3
- CODEVS-1082-线段树练习3-splay
- 【金阳光测试】Android自动化测试第一季第四讲—Robotium原理初步和录制器
- 多态、重写与隐藏
- Inna MTV
- 以数组作为存储结构的栈
- 计算机网络练习题
- 线段树练习3
- hdu 5074 DP 2014鞍山现场赛题
- Boost学习笔记-智能指针
- hdu 5073
- OC_关于protocol的基本应用
- Oracle杀Session
- 解决异常: Unable to execute dex: Multiple dex files define
- 为iPhone 6设计自适应布局
- 项目一 利用循环求和 for语句