关于二进制&异或&树状数组的问题研究

Posted blowhail

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于二进制&异或&树状数组的问题研究相关的知识,希望对你有一定的参考价值。

 

 

首先,我们规定两个相邻二进制数的“差值”为对应位数不同的个数(eg:01与10的差值为2,011与100的差值为3),然后,如果我们再对相邻两个二进制数进行异或运算,它的结果将会是下面这图这样的。然后,如果我们把他们两个的值放入到树状数组中,就会发现它完美的符合树状数组的运算(差值即为树状数组中的A[i],异或后的值为C[i] )。

技术图片技术图片

 

之后,如果我们把异或后的值换成二进制的形式,将会变成下面这样。 

技术图片

 

似乎是因为每相邻两个二进制数的差值恰巧符合了树状数组的二分划分(?) 才让异或之后的值又恰巧等于了树状数组中C[i]的值?

 

感觉我对树状数组还只停留在表面,如果有dalao看到这篇文章并且明白其中的原因希望能够指教一下_(:з」∠)_

 

以上是关于关于二进制&异或&树状数组的问题研究的主要内容,如果未能解决你的问题,请参考以下文章

树状数组lowbit()函数原理的解释 x&(x^(x-1)) x&-x

算法#3树状数组&二叉索引树

简单树状数组

树状数组

[数据结构] 树状数组 的C程序实现

关于树状数组