51nod 1081 子段求和(线段树 | 树状数组 | 前缀和)
题目链接:子段求和
题意:n个数字序列,m次询问,每次询问从第p个开始L长度序列的子段和为多少。
题解:线段树区间求和 | 树状数组区间求和
线段树:
#include <cstdio>
#define LC(a) ((a<<1))
#define RC(a) ((a<<1)+1)
#define MID(a,b) ((a+b)>>1)
using namespace std; typedef long long ll;
const int N=5e4*;
ll ans=; struct node{
ll l,r,sum;
}tree[N]; void pushup(ll p){
tree[p].sum=tree[LC(p)].sum+tree[RC(p)].sum;
} void build(ll p,ll l,ll r){
tree[p].l=l;
tree[p].r=r;
tree[p].sum=;
if(l==r){
scanf("%lld",&tree[p].sum);
return;
}
build(LC(p),l,MID(l,r));
build(RC(p),MID(l,r)+,r);
pushup(p);
} void query(ll p,ll l, ll r){
if(r<tree[p].l||l>tree[p].r) return;
if(l<=tree[p].l&&r>=tree[p].r){
ans+=tree[p].sum;
return;
}
query(LC(p),l,r);
query(RC(p),l,r);
} int main(){ ll n,q;
scanf("%lld",&n);
build(,,n);
scanf("%lld",&q);
while(q--){
ans=;
ll st,len;
scanf("%lld%lld",&st,&len);
query(,st,st+len-);
printf("%lld\n",ans);
} return ;
}
树状数组:
#include <cstdio>
#define low(i) ((i)&(-i))
using namespace std; const int N=5e4+;
typedef long long ll;
ll a[N];
int n,q; struct TreeArray {
ll c[N];
void add(int pos,ll v) {
for(int i=pos;i<=n;i+=low(i)) c[i]+=v;
}
ll query(int pos) {
ll res=;
for(int i=pos;i;i-=low(i)) res+=c[i];
return res;
}
}p; int main(){
scanf("%d",&n);
for(int i=;i<=n;i++) scanf("%lld",&a[i]);
for(int i=;i<=n;i++) p.add(i,a[i]);
scanf("%d",&q);
while(q--){
int st,len;
scanf("%d%d",&st,&len);
printf("%lld\n",p.query(st+len-)-p.query(st-));
}
return ;
}
前缀和:
#include <cstdio>
#define low(i) ((i)&(-i))
using namespace std; const int N=5e4+;
typedef long long ll;
ll sum[N];
int n,q; int main(){
sum[]=;
scanf("%d",&n);
for(int i=;i<=n;i++){
scanf("%lld",&sum[i]);
sum[i]+=sum[i-];
}
scanf("%d",&q);
while(q--){
int st,len;
scanf("%d%d",&st,&len);
printf("%lld\n",sum[st+len-]-sum[st-]);
}
return ;
}
51nod 1081 子段求和(线段树 | 树状数组 | 前缀和)的更多相关文章
- 51NOD 1081 子段求和
1081 子段求和 给出一个长度为N的数组,进行Q次查询,查询从第i个元素开始长度为l的子段所有元素之和. 例如,1 3 7 9 -1,查询第2个元素开始长度为3的子段和,1 {3 7 9} ...
- (前缀和 内存分配)51NOD 1081 子段求和
给出一个长度为N的数组,进行Q次查询,查询从第i个元素开始长度为l的子段所有元素之和. 例如,1 3 7 9 -1,查询第2个元素开始长度为3的子段和,1 {3 7 9} -1.3 + 7 + 9 ...
- 51nod 1680区间求和 (dp+树状数组/线段树)
不妨考虑已知一个区间[l,r]的k=1.k=2....k=r-l+1这些数的答案ans(只是这一个区间,不包含子区间) 那么如果加入一个新的数字a[i](i = r+1) 则新区间[l, i]的答案为 ...
- FZU2013 A short problem —— 线段树/树状数组 + 前缀和
题目链接:https://vjudge.net/problem/FZU-2013 Problem 2013 A short problem Accept: 356 Submit: 1083Ti ...
- CSU - 1551 Longest Increasing Subsequence Again —— 线段树/树状数组 + 前缀和&后缀和
题目链接:http://acm.csu.edu.cn/csuoj/problemset/problem?pid=1551 题意: 给出一段序列, 删除其中一段连续的子序列(或者不删), 使得剩下的序列 ...
- Codeforces Round #365 (Div. 2) D. Mishka and Interesting sum (离线树状数组+前缀xor)
题目链接:http://codeforces.com/contest/703/problem/D 给你n个数,m次查询,每次查询问你l到r之间出现偶数次的数字xor和是多少. 我们可以先预处理前缀和X ...
- 【51NOD-0】1081 子段求和
[算法]树状数组(区间和) [题解]记得开long long #include<cstdio> #include<cstring> #include<algorithm& ...
- ACM学习历程—HDU5700 区间交(树状数组 && 前缀和 && 排序)
http://acm.hdu.edu.cn/showproblem.php?pid=5700 这是这次百度之星初赛2B的第五题.省赛回来看了一下,有这样一个思路:对于所有的区间排序,按左值排序. 然后 ...
- MooFest 树状数组 + 前缀和
比较友好的数据结构题 建议读者好好思考思考--. 可以分析出与前缀和的关系, 之后就愉快的套起树状数组辣 #include <cstdio> #include<queue> # ...
随机推荐
- js数据放入缓存,需要再调用
再贴代码之前先描述下,这个技术应用的场景:一个页面的http请求次数能少点就少,这样大大提高用户体验.所以再一个页面发起一个请求,把所有数据都拿到后储存在缓存里面,你想用的时候再调用出来,这个是非常好 ...
- axios的增删改查。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- CentOS 6.4 源码安装MySQL 5.6
1.安装前准备工作 1.1 必备的包 gcc/g++ :MySQL 5.6开始,需要使用g++进行编译.cmake :MySQL 5.5开始,使用cmake进行工程管理,cmake需要2.8以上版本. ...
- Git本地仓库push至GitHub远程仓库每次输入账户密码问题解决(亲测可行)
在使用git push命令将本地仓库内容推送至GitHub远程仓库的每一次git都要让我们输入GitHub的用户名和密码.这着实让我们心烦.我们会有疑问,我明明设置了公钥呀!怎么还需要输入账户和密码? ...
- 在JavaEE中使用Hibernate框架
我们必须要了解一些Hibernate基础对象,如下: 配置对象 配置对象是你在任何 Hibernate 应用程序中创造的第一个 Hibernate 对象,并且经常只在应用程序初始化期间创造.它代表了 ...
- NOIP2016提高组复赛C 愤怒的小鸟
题目链接:http://uoj.ac/problem/265 题目大意: 太长了不想概括... 分析: 状压DP的模板题,把所有可能的抛物线用二进制表示,然后暴力枚举所有组合,详情见代码内注释 代码如 ...
- class面向对象-2
hasattr/getattr/setattr/delattr #通过字符串判断/获取/新增/删除对象属性或方法 class att(object): def __init__(self,var): ...
- 不使用DataContext直接将ViewModels绑定到ItemsControl控件
在常规的MVVM设计模式中,都是通过DataContext将ViewModels的一个对象绑定到View的DataContext中,从而完成相应地绑定,在本文中我们将通过另外的一种思路来将ViewMo ...
- vue & @on-change !== on-change @on-change === @change
vue & @on-change !== on-change @on-change === @change https://jsfiddle.net/Lasx1fod/ i-switch ht ...
- linux下更改MySQL数据库存储路径
参考地址:1.https://blog.csdn.net/ArnoBM/article/details/83008212 2.http://www.cnblogs.com/lyongde/p/3725 ...