• <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>
            我叫張小黑
            張小黑的掙扎生活
            posts - 66,  comments - 109,  trackbacks - 0

            一維情況:

             

            設序列的元素存儲在a[]中,a的下標是1..n的正整數,需要動態地更新某個a[x]的值,同時要求出a[x1]到a[y1]這一段所有元素的和。

            如果要動態更新m次。。我們顯然可以用o(mn)的暴力弄出來
            其實可以o(mlogn)的;

            在李睿的論文里提出了一種新的數據結構:
            很巧妙,很強大:
            對于序列a[],我們設一個數組C,其中 (k為i在二進制下末尾0的個數)。

            c[i]=a[i]+a[i-1]+...+
            a[i-2^k+1]//這一項的最后一位一定是0
            包含a[x]的c序列:

            c[x]=a[x]+a[x-1]+...+a[x-2^k+1]
            c[x+2^k]=a[x+2^k]+a[x+2^k-1]...+a[x]+...+a[x-2^k+1]
            ....
            一直加到<=S的狀況


            針對這個情況。。我們有兩個實現。。一個是update(),另一個是統計的操作
            如果針對上面的統計就是求給定區間的sum (x,y)=sum(1,y)-sum(1,x);

            procedure UPDATA(x,A)
            begin
                 p←x
                 
            while (p<=n) do
                 begin
                     C[p]←C[p]
            +A
                        p←p
            +LOWBIT(p)
                 
            end
            end 

            求a[1]-a[x]的和
            function  SUM(x)
            begin
                ans ← 
            0
            p ← x
            while (p>0do
                 begin
                      ans←ans
            +C[p]
                      p←p
            -LOWBIT(p)
                 
            end
            return ans
            end 

            我們通過一維的可以擴展成二維的:(IOI  MOBILES
            以下是我的這代碼:

            #include
            <iostream>
            #define MaxS 
            1025
            #define L(a) (a
            &(a^(a-1)))
            int S,x,y,A,L,B,R,T;
            int c[MaxS][MaxS];
            void update()
            {
                
            //x<=i<S的c[i][y]更新
                
            int i,j;
                
            for(i=x;i<=S;i+=L(i))
                    
            for(j=y;j<=S;j+=L(j))
                        c[i][j]
            +=A;
            }
            int compute(int x,int y)
            {
                
            int result=0,i,j;
                
            for(i=x;i>0;i-=L(i))
                    
            for(j=y;j>0;j-=L(j))
                        result
            +=c[i][j];
                return result;
            }
            int main()
            {
                
            int oper,ans;
                
            while(scanf("%d",&oper)&&oper!=3)
                {
                    switch (oper)
                    {
                    
            case 0:
                        scanf(
            "%d",&S);
                        memset(c,
            0,sizeof(c));
                        break;
                    
            case 1:
                        scanf(
            "%d%d%d",&x,&y,&A);
                        x
            ++,y++;
                        update();
                        break;
                    
            case 2:
                        scanf(
            "%d%d%d%d",&L,&B,&R,&T);
                        L
            ++,B++,R++,T++;
                        ans
            =compute(R,T)-compute(L-1,T)-compute(R,B-1)+compute(L-1,B-1);
                        printf(
            "%d\n",ans);
                        break;
                    }
                }
                return 
            0;
            }
            posted on 2008-07-13 19:40 zoyi 閱讀(289) 評論(0)  編輯 收藏 引用 所屬分類: acm數據結構
            歡迎光臨 我的白菜菜園

            <2008年2月>
            272829303112
            3456789
            10111213141516
            17181920212223
            2425262728291
            2345678

            常用鏈接

            留言簿(8)

            隨筆分類

            隨筆檔案

            文章檔案

            相冊

            acmer

            online judge

            隊友

            技術

            朋友

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            国产AⅤ精品一区二区三区久久| 久久天天躁狠狠躁夜夜av浪潮| 18岁日韩内射颜射午夜久久成人| 亚洲AV日韩精品久久久久久| 久久ZYZ资源站无码中文动漫| 国产毛片欧美毛片久久久| 亚洲中文字幕久久精品无码APP | 久久亚洲中文字幕精品一区| 伊人情人综合成人久久网小说 | 久久综合中文字幕| 热久久国产欧美一区二区精品| 亚洲精品无码久久久久去q| 青青草国产精品久久久久| 久久亚洲AV成人无码软件| 免费国产99久久久香蕉| 狠狠精品久久久无码中文字幕 | 久久久久久综合一区中文字幕| 亚洲美日韩Av中文字幕无码久久久妻妇| 久久综合给久久狠狠97色| 久久精品国产精品亚洲艾草网美妙| 久久A级毛片免费观看| 亚洲国产成人久久综合一区77| 久久婷婷久久一区二区三区| 亚洲中文久久精品无码| 欧美性大战久久久久久| 久久精品中文字幕一区| 狠狠色丁香婷婷久久综合不卡| 久久精品国产色蜜蜜麻豆| 亚洲国产精品成人AV无码久久综合影院 | 亚洲国产精品一区二区久久hs | 成人国内精品久久久久影院VR| 久久强奷乱码老熟女网站 | 精品久久亚洲中文无码| 亚洲国产成人乱码精品女人久久久不卡 | 麻豆成人久久精品二区三区免费| 欧美久久天天综合香蕉伊| 久久亚洲色一区二区三区| 久久综合狠狠综合久久97色| 午夜精品久久久久久影视777| 久久天天躁狠狠躁夜夜av浪潮| 午夜精品久久久久久|