博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
线段树
阅读量:6695 次
发布时间:2019-06-25

本文共 4426 字,大约阅读时间需要 14 分钟。

(CodeVS:1082)

C++指针版

#include 
#include
#include
#define ll long longusing namespace std;struct rec{ ll l,r,delta,sum; rec *lc,*rc;};rec *root;ll l,r,add,n,m,tmp;void update(rec *now,ll l,ll r,ll add){ if ((l<=now->l)&&(now->r<=r)) { now->delta+=add; return; } if (l<=(now->l+now->r)/2) update(now->lc,l,r,add); if (r>(now->l+now->r)/2) update(now->rc,l,r,add); now->sum=now->lc->sum+(now->lc->r-now->lc->l+1)*now->lc->delta; now->sum+=now->rc->sum+(now->rc->r-now->rc->l+1)*now->rc->delta;}void build(rec *now,ll l,ll r){ now->l=l;now->r=r; if (l==r) { scanf("%lld",&now->sum); now->lc=NULL;now->rc=NULL; return; } now->lc=new rec; now->rc=new rec; build(now->lc,l,(l+r)/2); build(now->rc,(l+r)/2+1,r); now->sum=now->lc->sum+now->rc->sum;}ll query(rec *now,ll l,ll r){ ll ret=0; if ((l<=now->l)&&(now->r<=r))return now->sum+now->delta*(now->r-now->l+1); now->lc->delta+=now->delta; now->rc->delta+=now->delta; now->sum+=now->delta*(now->r-now->l+1); now->delta=0; if (l<=(now->l+now->r)/2)ret=query(now->lc,l,r); if (r>(now->r+now->l)/2)ret+=query(now->rc,l,r); return ret;}int main(){ root=new rec; scanf("%lld",&n); build(root,1,n); scanf("%lld",&m); for (int i=1;i<=m;i++) { scanf("%lld",&tmp); if (tmp==1) { scanf("%lld %lld %lld",&l,&r,&add); update(root,l,r,add); } if (tmp==2) { scanf("%lld %lld",&l,&r); printf("%lld\n",query(root,l,r)); } }}

指针+读入优化

#include 
#include
#include
#define ll long longusing namespace std;struct rec{ ll delta,sum,l,r; rec *lc,*rc;};rec *root;ll l,r,add,n,m,tmp;void read(ll &k){ int f=1;char c=getchar();k=0; while (c<'0'||c>'9') c=='-'&&(f=-1),c=getchar(); while (c>='0'&&c<='9')k=k*10+c-'0',c=getchar(); k*=f;}void build(rec *now,ll l,ll r){ now->l=l;now->r=r; if (l==r){read(now->sum);return;} now->lc=new rec; now->rc=new rec; build(now->lc,l,(l+r)>>1); build(now->rc,((l+r)>>1)+1,r); now->sum=now->lc->sum+now->rc->sum;}void update(rec *now,ll l,ll r,ll add){ if ((l<=now->l)&&(now->r<=r)){now->delta+=add;return;} if (l<=(now->l+now->r)>>1) update(now->lc,l,r,add); if (r>(now->l+now->r)>>1) update(now->rc,l,r,add); now->sum=now->lc->sum+(now->lc->r-now->lc->l+1)*now->lc->delta; now->sum+=now->rc->sum+(now->rc->r-now->rc->l+1)*now->rc->delta;}ll query(rec *now,ll l,ll r){ if ((l<=now->l)&&(now->r<=r))return now->sum+now->delta*(now->r-now->l+1); ll ret=0; now->lc->delta+=now->delta; now->rc->delta+=now->delta; now->sum+=now->delta*(now->r-now->l+1); now->delta=0; if (l<=(now->l+now->r)>>1)ret=query(now->lc,l,r); if (r>(now->r+now->l)>>1)ret+=query(now->rc,l,r); return ret;}int main(){ root=new rec; read(n); build(root,1,n); scanf("%lld",&m); for (int i=1;i<=m;i++) { scanf("%lld",&tmp); if (tmp==1) { read(l);read(r);read(add); update(root,l,r,add); } if (tmp==2) { read(l);read(r); printf("%lld\n",query(root,l,r)); } }}

数组模拟+读入优化

#include 
#include
#include
#define ll long longusing namespace std;ll n,m,l,r,tmp,add;const int maxn=200000;ll le[maxn*4],ri[maxn*4],delta[maxn*4],sum[maxn*4];void read(ll &k){ k=0;ll f=1;char c=getchar(); while (c<'0'||c>'9')c=='-'&&(f=-1),c=getchar(); while (c>='0'&&c<='9')k=k*10+c-'0',c=getchar(); k*=f;}void build(ll l,ll r,ll cur){ le[cur]=l;ri[cur]=r; if (l==r){read(sum[cur]);return;} build(l,(l+r)>>1,cur*2); build(((l+r)>>1)+1,r,cur*2+1); sum[cur]=sum[cur*2]+sum[cur*2+1];}ll query(ll l,ll r,ll cur){ if (l<=le[cur]&&ri[cur]<=r)return sum[cur]+delta[cur]*(ri[cur]-le[cur]+1); ll ret=0; delta[cur*2]+=delta[cur]; delta[cur*2+1]+=delta[cur]; sum[cur]+=delta[cur]*(ri[cur]-le[cur]+1); delta[cur]=0; if (l<=(le[cur]+ri[cur])>>1)ret=query(l,r,cur*2); if (r>(le[cur]+ri[cur])>>1)ret+=query(l,r,cur*2+1); return ret;}void update(ll l,ll r,ll add,ll cur){ if (l<=le[cur]&&r>=ri[cur]){delta[cur]+=add;return;} if (l<=(le[cur]+ri[cur])>>1)update(l,r,add,cur*2); if (r>(le[cur]+ri[cur])>>1)update(l,r,add,cur*2+1); sum[cur]=sum[cur*2]+delta[cur*2]*(ri[cur*2]-le[cur*2]+1); sum[cur]+=sum[cur*2+1]+delta[cur*2+1]*(ri[cur*2+1]-le[cur*2+1]+1);}int main(){ read(n); build(1,n,1); read(m); for (int i=0;i

  

转载于:https://www.cnblogs.com/mczhuang/p/7125625.html

你可能感兴趣的文章
数据结构与算法学习(六)(续)
查看>>
我的友情链接
查看>>
[转载]信息化发展阶段的划分
查看>>
网页制作常用代码
查看>>
第10章 关联容器
查看>>
自动化运维工具ansible源码安装方法
查看>>
hyperscan 安装
查看>>
C语言基础之--printf函数
查看>>
Linux中环境变量文件及配置
查看>>
我的友情链接
查看>>
菜鸟学Linux 第106篇笔记 cobbler
查看>>
Realm数据库简介
查看>>
windows7快速切换ip批处理
查看>>
第二章 LYNC2010产品功能介绍
查看>>
Linux基础--进程管理和作业控制
查看>>
Linux 查看服务器开放的端口号
查看>>
left join on 和where条件的放置
查看>>
关于电脑程序无响应的常见原因以及解决办法
查看>>
MFC_UpdateData()函数的用法
查看>>
MAC安装MySQL-python报错:EnvironmentError: mysql_config not found
查看>>