青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

為你寫詩

c/c++
隨筆 - 32, 文章 - 0, 評論 - 3, 引用 - 0
數據加載中……

樹狀數組的理解和應用

樹狀數組

樹狀數組(Binary Indexed Tree)是又一種靜態的樹結構。它的首要用途是用于維護前綴和,也即:一數組a[1..n],隨時會改變其中某a[i],還會詢問s[i]=a[1]+a[2]+…+a[i],樹狀數組可完美解決這一問題。

定義數組c[0..n],其中c[i]=a[i-2^k+1]+a[i-a^k+2]+…+a[i],其中k為i在二進制下末尾0的個數。當我們改變一個a[i]時,會有很多c[i]隨之改變;若需查詢某個s[i],需要累加多個c[i]。好在確定需要改變或累加的元素都可以用比較簡便的方法得出,這方法的核心就是lowbit值。

定義lowbit(x)=x&(x^(x-1)),它相當于將最右邊的1左邊的東西全部去掉。若需改變a[i],則c[i]、c[i+lowbit(i)]、c[i+lowbit(i)+lowbit(i+lowbit(i)]……就是需要改變的c數組中的元素。若需查詢s[i],則c[i]、c[i-lowbit(i)]、c[i-lowbit(i)-lowbit(i-lowbit(i))]……就是需要累加的c數組中的元素。這看上去有些玄妙,我覺得其實也可以不用透徹理解。

一維的樹狀數組的每個操作的復雜度都是O(logn)的,非常高效。它可以擴充為n維,這樣每個操作的復雜度就變成了O((logn)^n),在n不大的時候仍然完全可以接受。擴充的方法就是將原來改變和查詢的函數中的一個循環改成嵌套的n個循環在n維的c數組中操作。

要注意樹狀樹組能處理的是下標為1..n的數組,絕對不能出現下標為0的情況。因為lowbit(0)=0,這樣會陷入死循環。對于我這個從來都用C語言思考的家伙來說,這一點格外需要注意。

似乎樹狀數組也可以用來解決一些與前綴和關聯不大的問題,例如NOI2004的cashier,但我還不太會(那題我只會用平衡樹或線段樹或虛二叉樹解)。

示例程序:ural1470.cpp(三維的樹狀數組)

附:

 

【引言】

          在解題過程中,我們有時需要維護一個數組的前綴和S[i]=A[1]+A[2]+...+A[i]。

          但是不難發現,如果我們修改了任意一個A[i],S[i]、S[i+1]...S[n]都會發生變化。

          可以說,每次修改A[i]后,調整前綴和S[]在最壞情況下會需要O(n)的時間。

          當n非常大時,程序會運行得非常緩慢。

          因此,這里我們引入“樹狀數組”,它的修改與求和都是O(logn)的,效率非常高。

【理論】

          為了對樹狀數組有個形 象的認識,我們先看下面這張圖。

       

          如圖所示,紅色矩形表示的數組C[]就是樹狀數組。

          這里,C[i]表示A[i-2^k+1]到A[i]的和,而k則是i在二進制時末尾0的個數,

          或者說是i用2的冪方和表示時的最小指數。

         ( 當然,利用位運算,我們可以直接計算出2^k=i&(i^(i-1)) )

          同時,我們也不難發現,這個k就是該節點在樹中的高度,因而這個樹的高度不會超過logn。

          所以,當我們修改A[i]的值時,可以從C[i]往根節點一路上溯,調整這條路上的所有C[]即可,

          這個操作的復雜度在最壞情況下就是樹的高度即O(logn)。  

          另外,對于求數列的前n項和,只需找到n以前的所有最大子樹,把其根節點的C加起來即可。

          不難發現,這些子樹的數目是n在二進制時1的個數,或者說是把n展開成2的冪方和時的項數,

          因此,求和操作的復雜度也是O(logn)。

          接著,我們考察這兩種操作下標變化的規律:

          首先看修改操作:

          已知下標i,求其父節點的下標。
          我們可以考慮對樹從邏輯上轉化:

            
         
         如圖,我們將子樹向右對稱翻折,虛擬出一些空白結點(圖中白色),將原樹轉化成完全二叉樹。

         有圖可知,對于節點i,其父節點的下標與翻折出的空白節點下標相同。

         因而父節點下標 p=i+2^k  (2^k是i用2的冪方和展開式中的最小冪,即i為根節點子樹的規模)

         即  p = i + i&(i^(i-1)) 。

         接著對于求和操作:

         因為每棵子樹覆蓋的范圍都是2的冪,所以我們要求子樹i的前一棵樹,只需讓i減去2的最小冪即可。

         即  p = i - i&(i^(i-1)) 。

        

         至此,我們已經比較詳細的分析了樹狀數組的復雜度和原理。

         在最后,我們將給出一些樹狀數組的實現代碼,希望讀者能夠仔細體會其中的細節。

【代碼】

  求最小冪2^k:


int Lowbit(int t) 
{ 
    return t & ( t ^ ( t - 1 ) ); 
} 

             
  求前n項和:


int Sum(int end) 
{ 
    int sum = 0; 
    while(end > 0) 
    { 
        sum += in[end]; 
        end -= Lowbit(end); 
    } 
    return sum; 
} 

 對某個元素進行加法操作: 

void plus(int pos , int num) 
{ 
    while(pos <= n) 
    { 
          in[pos] += num; 
          pos += Lowbit(pos); 
    } 
} 



posted on 2011-07-21 20:34 pp_zhang 閱讀(1563) 評論(0)  編輯 收藏 引用 所屬分類: Ialgo

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美黄色一区二区| 欧美一级理论性理论a| 久久午夜视频| 亚洲美女毛片| 免费日韩成人| 午夜欧美大尺度福利影院在线看| 亚洲欧美日韩在线一区| 在线亚洲自拍| 国产精品一区二区男女羞羞无遮挡| 亚洲精品一区在线观看| 亚洲激情成人在线| 麻豆精品精华液| 欧美一区二区精品久久911| 在线看国产一区| 樱桃成人精品视频在线播放| 91久久香蕉国产日韩欧美9色 | 欧美激情国产日韩| 亚洲美女免费精品视频在线观看| 在线观看福利一区| 亚洲国产精品一区制服丝袜| 亚洲国产cao| 欧美日韩www| 亚洲性av在线| 欧美成人亚洲成人日韩成人| 在线看欧美视频| 国产精品美女www爽爽爽视频| 西瓜成人精品人成网站| 免费视频一区二区三区在线观看| 99精品99| 欧美亚洲视频| 亚洲一区二区三区四区五区黄| 欧美日韩在线三级| 欧美综合激情网| 亚洲激情成人网| 亚洲一区二区三区免费视频| 亚洲精品国久久99热| 国产情人综合久久777777| 亚洲精品一区二区三区在线观看| 翔田千里一区二区| 一区二区三欧美| 这里只有精品在线播放| 亚洲第一综合天堂另类专| 午夜亚洲福利在线老司机| 男人天堂欧美日韩| 欧美国产免费| 久久婷婷国产综合精品青草| 夜夜嗨av一区二区三区四季av| 欧美成人午夜激情在线| 国产亚洲一级| 亚洲欧美激情四射在线日| 亚洲在线观看视频网站| 亚洲欧美日韩一区在线| 欧美一区二区三区免费观看视频| 亚洲宅男天堂在线观看无病毒| 在线观看欧美视频| 欧美一级理论片| 亚洲中午字幕| 另类天堂视频在线观看| 国产精品视频导航| 亚洲欧美大片| 亚洲娇小video精品| 性8sex亚洲区入口| 欧美理论电影在线观看| 国产精品一区二区在线观看不卡| 久久精品最新地址| 国产免费亚洲高清| 在线亚洲激情| 久久亚洲精品中文字幕冲田杏梨| 老色批av在线精品| 久久久久免费视频| 国产一区二区无遮挡| 久久嫩草精品久久久久| 麻豆精品一区二区综合av| 一本综合久久| 久久精品夜夜夜夜久久| 亚洲一区二区毛片| 国产日韩一区在线| 国产精品久久久久久久浪潮网站 | 国产视频一区在线观看一区免费| 久久综合九色九九| 欧美午夜宅男影院| 你懂的视频欧美| 国产久一道中文一区| 一区二区三区视频在线看| 亚洲精品一区二| 另类亚洲自拍| 久久综合九色综合久99| 国产欧美日韩精品丝袜高跟鞋 | 久久中文字幕一区二区三区| 欧美性猛交xxxx乱大交退制版| 国内精品久久久久久影视8| 日韩一区二区精品在线观看| 亚洲人成高清| 老鸭窝亚洲一区二区三区| 久久夜色精品国产欧美乱极品| 国产一区在线播放| 久久精品99| 鲁大师影院一区二区三区| 国产亚洲欧美一区二区三区| 亚洲欧美精品suv| 欧美伊人影院| 国产亚洲人成a一在线v站| 午夜视频一区二区| 久久精品二区| 国内精品久久久久国产盗摄免费观看完整版| 亚洲一区二区三区精品在线| 亚洲女性喷水在线观看一区| 欧美视频导航| 亚洲网站在线播放| 欧美一区三区三区高中清蜜桃| 国产欧美二区| 久久精品国产99国产精品澳门| 美女黄网久久| 亚洲日本一区二区| 欧美午夜久久久| 亚洲欧美日韩精品久久奇米色影视| 午夜精品久久久久久久99黑人| 国产欧美一区二区色老头| 久久久久成人精品| 91久久国产综合久久| 亚洲一卡二卡三卡四卡五卡| 国产精品一区2区| 久久精品综合网| 亚洲另类一区二区| 久久se精品一区精品二区| 在线日韩欧美| 欧美视频亚洲视频| 久久精品国产清高在天天线 | 欧美视频不卡中文| 欧美一区二区日韩| 亚洲国产二区| 欧美影片第一页| 亚洲韩国一区二区三区| 国产精品啊啊啊| 久久久久久9| 一本到12不卡视频在线dvd| 久久久久久久高潮| 99视频一区二区| 国产亚洲美州欧州综合国| 欧美精品1区2区3区| 香蕉久久国产| 亚洲精品社区| 美女视频黄免费的久久| 亚洲一区二区三区激情| 原创国产精品91| 国产精品久久久久久av福利软件| 久久人体大胆视频| 亚洲永久精品国产| 亚洲国产视频一区| 久久久久88色偷偷免费| 一本一本久久a久久精品牛牛影视| 国产日韩一区二区| 欧美日韩在线视频首页| 麻豆精品精华液| 久久精品欧美| 亚洲欧美国产不卡| 99成人精品| 亚洲国产精品综合| 久久久99精品免费观看不卡| 亚洲一区在线免费| 99热这里只有精品8| 亚洲高清三级视频| 免费在线成人| 久久不射中文字幕| 亚洲一区二区视频在线| 亚洲毛片av在线| 亚洲欧洲日韩综合二区| 欧美成人激情视频| 另类欧美日韩国产在线| 久久久国际精品| 久久成人免费| 久久gogo国模裸体人体| 亚欧美中日韩视频| 亚洲男女自偷自拍| 香蕉成人久久| 性欧美超级视频| 午夜精品久久一牛影视| 亚洲欧美日韩国产| 香蕉精品999视频一区二区| 亚洲免费一级电影| 亚洲欧美日韩国产| 欧美在线观看天堂一区二区三区| 亚洲影院免费| 午夜在线视频观看日韩17c| 午夜精品美女久久久久av福利| 午夜宅男欧美| 久久久不卡网国产精品一区| 久久久久一区二区三区| 免费看的黄色欧美网站| 欧美国产1区2区| 亚洲黄色一区| 999亚洲国产精| 亚洲午夜激情免费视频| 亚洲欧美日本日韩| 欧美在线三级| 蜜桃久久精品乱码一区二区| 欧美黄色小视频| 国产精品久久久一区二区三区| 国产农村妇女精品一二区| 好吊妞**欧美|