码迷,mamicode.com
首页 > 编程语言 > 详细

树状数组--前n项和;

时间:2015-06-02 13:08:07      阅读:117      评论:0      收藏:0      [点我收藏+]

标签:

技术分享

树状数组是和线段树类似的数据结构,基本上树状数组可以做的线段树都可以做;

树状数组就是一个数组,在信息记录上有一些特点,以动态求前n项和为例:可以改变数组的某一个元素,求前n项和;

数组tree[ i ]记录的是A[ i - lowbit ( i )+1]~A[ i ]的和,lowbit(i),表示i的最低二进制是多少;表现在数组编号上就是上面的图中表现的东西;

求前n项和的操作:

    

 1 #include<iostream>
 2 #include<cstdio>
 3 using namespace std;
 4 #define MAX 1000
 5 inline int lowbit(int x)
 6 {
 7     return x&(-x);
 8 }
 9 int main()
10 {
11     int tree[MAX+10],a[MAX];
12     for(int i=1;i<=MAX;i++)//编号从1开始;
13         scanf("%d",&a[i]);
14     //求前n项和的操作;
15     int n,ans=0;
16     scanf("%d",&n);
17     for(int i=n;i>0;i-=lowbit(i))
18     {
19         ans+=tree[i];
20     }
21     //给第n项数加m;
22     int m;
23     scanf("%d%d",&n,&m);
24     for(int i=1;i<=MAX;i+=lowbit(i))
25     {
26         tree[i]+=m;
27     }
28     return 0;
29 }

 

树状数组--前n项和;

标签:

原文地址:http://www.cnblogs.com/by-1075324834/p/4546088.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!