1081 线段树练习 2

时间限制: 1 s

空间限制: 128000 KB

题目等级 : 大师 Master

传送门

题目描述 Description

给你N个数,有两种操作

1:给区间[a,b]的所有数都增加X

2:询问第i个数是什么?

输入描述 Input Description

第一行一个正整数n,接下来n行n个整数,再接下来一个正整数Q,表示操作的个数. 接下来Q行每行若干个整数。如果第一个数是1,后接3个正整数a,b,X,表示在区间[a,b]内每个数增加X,如果是2,后面跟1个整数i, 表示询问第i个位置的数是多少。

输出描述 Output Description

对于每个询问输出一行一个答案

样例输入 Sample Input

3

1

2

3

2

1 2 3 2

2 3

样例输出 Sample Output

5

数据范围及提示 Data Size & Hint

数据范围

1<=n<=100000

1<=q<=100000

/*
裸线段树.
单点查询+区间修改.
*/
#include<iostream>
#include<cstdio>
#define MAXN 100001
using namespace std;
struct data
{
int l,r;
int lc,rc;
int sum;
int bj;
}
tree[MAXN*4];
int aa[MAXN+10],n,m,cut,tot;
void bluid(int l,int r)
{
int k=++cut;
tree[k].l=l;
tree[k].r=r;
if(l==r)
{
tree[k].sum=aa[l];
return ;
}
int mid=(l+r)>>1;
tree[k].lc=cut+1;
bluid(l,mid);
tree[k].rc=cut+1;
bluid(mid+1,r);
tree[k].sum=tree[tree[k].lc].sum+tree[tree[k].rc].sum;
}
void updata(int k)
{
tree[tree[k].lc].sum+=
tree[k].bj*(tree[tree[k].lc].r-tree[tree[k].lc].l+1);
tree[tree[k].rc].sum+=
tree[k].bj*(tree[tree[k].rc].r-tree[tree[k].rc].l+1);
tree[tree[k].lc].bj+=tree[k].bj;
tree[tree[k].rc].bj+=tree[k].bj;
tree[k].bj=0;
}
void add(int k,int l,int r,int add1)
{
if(l<=tree[k].l&&tree[k].r<=r)
{
tree[k].bj+=add1;
tree[k].sum+=add1*(tree[k].r-tree[k].l+1);
return;
}
if(tree[k].bj) updata(k);
int mid=(tree[k].l+tree[k].r)>>1;
if(l<=mid) add(tree[k].lc,l,r,add1);
if(r>mid) add(tree[k].rc,l,r,add1);
tree[k].sum=tree[tree[k].lc].sum+tree[tree[k].rc].sum;
}
int query(int k,int l,int r)
{
if(l<=tree[k].l&&tree[k].r<=r)
{
return tree[k].sum;
}
if(tree[k].bj) updata(k);
int mid=(tree[k].l+tree[k].r)>>1;
if(l<=mid) return query(tree[k].lc,l,r);
if(r>mid) return query(tree[k].rc,l,r);
}
int main()
{
int x,a,b,add1;
cin>>n;
for(int i=1;i<=n;i++)
{
cin>>aa[i];
}
bluid(1,n);
cin>>m;
for(int i=1;i<=m;i++)
{
scanf("%d",&x);
if(x==1)
{
scanf("%d %d %d",&a,&b,&add1);
add(1,a,b,add1);
}
else
{
scanf("%d",&a);
printf("%d\n",query(1,a,a));
}
}
}
/*
树状数组 区间修改 单点查询.
比线段树不知道要快到那里去.
和区间修改维护的东西不同.
差分化区间修改为单点修改.
例:[2,5]+2 只需处+2 6处-2即可.
*/
#include<cstdio>
#include<iostream>
#define MAXN 100001
int s[MAXN],n,x,y,m,z;
int read(){
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9') {if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9')x=x*10+ch-48,ch=getchar();
return x*f;
}
int lowbit(int t){
return t&-t;
}
void add(int t,int x){
while(t<=n){
s[t]+=x;
t+=lowbit(t);
}
}
int query(int x){
int tot=0;
while(x){
tot+=s[x];
x-=lowbit(x);
}
return tot;
}
int main(){
n=read();
for(int i=1;i<=n;i++){
x=read();
add(i,x);add(i+1,-x);
}
m=read();
for(int i=1;i<=m;i++){
z=read();
if(z==1){
x=read();y=read();z=read();add(x,z);add(y+1,-z);
}
else{
x=read();printf("%d\n",query(x));
}
}
return 0;
}

Codevs 1081 线段树练习 2的更多相关文章

  1. codevs——1081 线段树练习 2

    1081 线段树练习 2  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 大师 Master 题解       题目描述 Description 给你N个数,有两种操作 1:给 ...

  2. codevs 1081 线段树练习2 (线段树)

    题目: 题目描述 Description 给你N个数,有两种操作 1:给区间[a,b]的所有数都增加X 2:询问第i个数是什么? 输入描述 Input Description 第一行一个正整数n,接下 ...

  3. codevs 1081 线段树练习 2 线段树

    题目描述 Description 给你N个数,有两种操作 1:给区间[a,b]的所有数都增加X 2:询问第i个数是什么? 输入描述 Input Description 第一行一个正整数n,接下来n行n ...

  4. Codevs 1081 线段树练习2

    时间限制: 1 s  空间限制: 128000 KB  题目等级 : 大师 Master   题目描述 Description 给你N个数,有两种操作 1:给区间[a,b]的所有数都增加X 2:询问第 ...

  5. codevs 1081 线段树练习 2 区间更新 单点查询 无lazy

    题目描述 Description 给你N个数,有两种操作 1:给区间[a,b]的所有数都增加X 2:询问第i个数是什么? 输入描述 Input Description 第一行一个正整数n,接下来n行n ...

  6. codevs 1082 线段树练习 3(区间维护)

    codevs 1082 线段树练习 3  时间限制: 3 s  空间限制: 128000 KB  题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...

  7. codevs 1080 线段树点修改

    先来介绍一下线段树. 线段树是一个把线段,或者说一个区间储存在二叉树中.如图所示的就是一棵线段树,它维护一个区间的和. 蓝色数字的是线段树的节点在数组中的位置,它表示的区间已经在图上标出,它的值就是这 ...

  8. codevs 1082 线段树区间求和

    codevs 1082 线段树练习3 链接:http://codevs.cn/problem/1082/ sumv是维护求和的线段树,addv是标记这歌节点所在区间还需要加上的值. 我的线段树写法在运 ...

  9. codevs 1080 线段树练习 CDQ分治

    codevs 1080 线段树练习 http://codevs.cn/problem/1080/  时间限制: 1 s  空间限制: 128000 KB   题目描述 Description 一行N个 ...

随机推荐

  1. 380. Insert Delete GetRandom O(1)

    经过昨天的消沉 今天我振作了 设计个数据结构,添加,删除,随机获取都是O(1). 怎么会有这么牛逼的数据结构,所以肯定相应的要耗费空间. 添加和获取耗时O(1)是Array的特性,或者说是Map/Ta ...

  2. Oracle的SCN与检查点机制

    Oracle的SCN与检查点机制 SCN在Oracle的文档上以多种形式出现,一种是System Change Number,另一种是System Commit Number,在大多数情况下,Syst ...

  3. php分页类代码和使用

    在这要说的一点就是如果你做的分页是有搜索条件的,那么就可以用下面的代码,然后调用之后在new Page()里面把连接加进去就可以了.例如: $href="http://www.***.cn/ ...

  4. DevExpress 用户控件 分页(中)

    说明: 1)具体调用请关注 看DevExpress 用户控件 分页(下) datanavi_ButtonClick 是DataNavigator的ButtonClikc事件 视图设计器: 分页用户控件 ...

  5. Session案例

    用户登入案例: 按一般的网站登入实例,用户在页面登入页输入账号.密码,验证通过后,在首页显示其"欢迎回来,xxx". 首先完成登入页login.html <!DOCTYPE ...

  6. java-常用快捷键

    alt+/:代码提示 ctrl+/:代码提示 ctrl+1:快速生成impl代码

  7. 查看数据库中有哪些活动的事务,对应的会话id,执行的语句

    select dbt.database_id, DB_NAME(dbt.database_id) '数据库名', dbt.transaction_id, at.name, at.transaction ...

  8. Spring框架:Spring容器具体解释

    Spring容器 Spring容器能够帮助你管理所有的Bean对象.专业术语称之为IoC控制反转.在传统的程序中.对象的生成都是由开发人员完毕的.而在控制反转中,对象的生成所有都交给框架完毕.这种优点 ...

  9. [TypeScript] Using Exclude and RootDir until File Globs Lands in 2.0.

    Files globs will be available in TypeScript 2.0, so in the meantime, we need to use "exclude&qu ...

  10. VoltDB公布4.0版本号,大步提高内存实时分析速度,进军操作数据库市场

    号称世界上最快的关系数据库的VoltDB与2014年1月29号(美国东部时间)公布下一代数据库4.0版本号.新的版本号有非常多地方的改进,大步挺高系统性能.在过去的13年,VoltdDB号称自己公司较 ...