• <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>
            心如止水
            Je n'ai pas le temps
            posts - 400,comments - 130,trackbacks - 0
            單個更新;維護區間和。
            以下是我的代碼:
            #include<iostream>
            #include
            <string>
            #define maxn 50007
            #define L(x) (x<<1)
            #define R(x) ((x<<1)+1)
            using namespace std;
            const string _1("Add");
            const string _2("Sub");
            const string _3("Query");
            const string end("End");
            struct
            {
                
            long a,b,sum;
            }seg[maxn
            *3];
            long test,n,r[maxn];
            void build(long node,long x,long y)
            {
                
            long mid=(x+y)>>1;
                seg[node].a
            =x;seg[node].b=y;
                
            if(x==y)
                  seg[node].sum
            =r[x];
                
            else if(x<y)
                {
                   build(L(node),x,mid);
                   build(R(node),mid
            +1,y);
                   seg[node].sum
            =seg[L(node)].sum+seg[R(node)].sum;
                }
            }
            void add(long node,long pos,long det)
            {
                
            long a=seg[node].a,b=seg[node].b,mid=(a+b)>>1;
                seg[node].sum
            +=det;
                
            if(a<b)
                {
                   
            if(mid>=pos)
                     add(L(node),pos,det);
                   
            else add(R(node),pos,det);
                }
            }
            void sub(long node,long pos,long det)
            {
                
            long a=seg[node].a,b=seg[node].b,mid=(a+b)>>1;
                seg[node].sum
            -=det;
                
            if(a<b)
                {
                   
            if(mid>=pos)
                     sub(L(node),pos,det);
                   
            else sub(R(node),pos,det);
                }
            }
            long getsum(long node,long x,long y)
            {
                
            long a=seg[node].a,b=seg[node].b,mid=(a+b)>>1,re=0;
                
            if(x<=a&&b<=y)
                  re
            =seg[node].sum;
                
            else
                {
                   
            if(mid>=x)
                     re
            +=getsum(L(node),x,y);
                   
            if(mid+1<=y)
                     re
            +=getsum(R(node),x,y);
                }
                
            return re;
            }
            int main()
            {
                
            long a,b;
                
            string cmd;
                cin
            >>test;
                
            for(long k=1;k<=test;k++)
                {
                   cin
            >>n;
                   
            for(long i=1;i<=n;i++) cin>>r[i];
                   build(
            1,1,n);
                   cout
            <<"Case "<<k<<":"<<endl;
                   
            while(cin>>cmd&&cmd!=end&&cin>>a>>b)
                     
            if(cmd==_1)
                       add(
            1,a,b);
                     
            else if(cmd==_2)
                       sub(
            1,a,b);
                     
            else if(cmd==_3)
                       cout
            <<getsum(1,a,b)<<endl;
                }
            return 0;
            }


            posted on 2010-02-24 10:50 lee1r 閱讀(429) 評論(0)  編輯 收藏 引用 所屬分類: 題目分類:數據結構
            AV无码久久久久不卡蜜桃| 日本久久久精品中文字幕| 欧美精品福利视频一区二区三区久久久精品 | 久久一区二区三区免费| 久久人人添人人爽添人人片牛牛| 久久久久亚洲av无码专区导航 | 狠狠色综合网站久久久久久久| 伊人色综合久久| 欧美激情精品久久久久久久九九九 | 大美女久久久久久j久久| 国产精品久久久久久久久久影院| 久久青青草原精品国产| 国产精品成人久久久久久久| 久久人妻无码中文字幕| 国产高潮久久免费观看| 无码AV波多野结衣久久| 精品乱码久久久久久夜夜嗨| 人妻精品久久无码专区精东影业| 久久99精品久久久久久秒播 | 久久人人爽人人爽人人片av麻烦| 久久se精品一区二区| 欧美日韩久久中文字幕| 国产成人无码精品久久久久免费| 中文字幕久久久久人妻| 天堂无码久久综合东京热| 一本一道久久精品综合| 久久人人爽人人爽人人AV| 婷婷久久精品国产| 品成人欧美大片久久国产欧美| 亚洲精品无码久久不卡| 精品久久久无码中文字幕| 99久久免费国产精品热| 国内精品人妻无码久久久影院 | 999久久久国产精品| 久久无码人妻一区二区三区午夜| 久久强奷乱码老熟女网站| 香蕉久久夜色精品国产小说| 精品亚洲综合久久中文字幕| 蜜桃麻豆WWW久久囤产精品| 波多野结衣久久精品| 免费无码国产欧美久久18|