学习笔记1-回顾树状数组与莫队思路

Posted ナイト

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了学习笔记1-回顾树状数组与莫队思路相关的知识,希望对你有一定的参考价值。

今天回顾了一下树状数组的有关内容。

可以说是今天才看懂树状数组的意思吧。。对之前的理解毫无印象..

现在这里马克一下

树状数组:

树状数组是用于存储数据的一种特殊的数据结构。具体的形状如下图:

技术分享

 

a数组是我们宏观普遍出现的数组形式,c就是相对的树状数组。

二进制条件下:

a[0]到a[1110]的和=c[1110]+c[0110]+c[0010];

修改a[1]时,受到影响的有c[1],c[10],c[100],c[1000].....

对于这样的运算,我们用到了&来计算。

lowbit();的作用是去掉高位1  (1100就是0100,1110就是0010,1000就是本身)

lowbit(k)=k&-k;

所以修改和读取的操作分别是:

void add(int k,int num)  
{  
    while(k<=n)  
    {  
        tree[k]+=num;  
        k+=k&-k;  
    }  
}  //修改
int read(int k)//1~k的区间和  
{  
    int sum=0;  
    while(k)  
    {  
        sum+=tree[k];  
        k-=k&-k;  
    }  
    return sum;  
}  //读取

当然,有一些时候数据会让你难以使用树状数组。比如,求区间中不同的数的个数(多次修改,多次询问),这个时候就可以用莫队来解决了~~

等我看完莫队再来补笔记....

树状数组时间复杂度O(lg n)

以上是关于学习笔记1-回顾树状数组与莫队思路的主要内容,如果未能解决你的问题,请参考以下文章

BZOJ 3289:Mato的文件管理(莫队算法+树状数组)

BZOJ 3289 Mato的文件管理(莫队+树状数组)

[bzoj3289]Mato的文件管理_莫队_树状数组

学习笔记——二维树状数组

51nod 1290 Counting Diff Pairs | 莫队 树状数组

BZOJ 2120: 数颜色 带修改的莫队算法 树状数组套主席树