• <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
            此題AC了不止一次,用線段樹和樹狀數(shù)組都實(shí)現(xiàn)過(guò)。
            以下是我的代碼:
            #include<cstdio>
            #define
             L(x) ((x)<<1)
            #define R(x) (((x)<<1)^1)
            using namespace std;
            const int kMaxn(100007);

            struct Node
            {
                
            int a,b,kind,sum;
            };

            int N,Q;
            Node tree[kMaxn
            <<2];

            void Build(int node,int x,int y)
            {
                tree[node].a
            =x;
                tree[node].b
            =y;
                tree[node].kind
            =0;
                
            if(x==y)
                    tree[node].sum
            =1;
                
            else
                {
                    
            int m((x+y)>>1);
                    Build(L(node),x,m);
                    Build(R(node),m
            +1,y);
                    tree[node].sum
            =tree[L(node)].sum+tree[R(node)].sum;
                }
            }

            void Modify(int node,int x,int y,int z)
            {
                
            if(x<=tree[node].a && tree[node].b<=y)
                {
                    tree[node].kind
            =z;
                    tree[node].sum
            =(tree[node].b-tree[node].a+1)*z;
                }
                
            else
                {
                    
            if(tree[node].kind)
                    {
                        tree[L(node)].kind
            =tree[R(node)].kind=tree[node].kind;
                        tree[node].kind
            =0;
                        tree[L(node)].sum
            =(tree[L(node)].b-tree[L(node)].a+1)*tree[L(node)].kind;
                        tree[R(node)].sum
            =(tree[R(node)].b-tree[R(node)].a+1)*tree[R(node)].kind;
                    }
                    
            int m((tree[node].a+tree[node].b)>>1);
                    
            if(x<=m)
                        Modify(L(node),x,y,z);
                    
            if(m+1<=y)
                        Modify(R(node),x,y,z);
                    tree[node].sum
            =tree[L(node)].sum+tree[R(node)].sum;
                }
            }

            int main()
            {
                
            int T;
                scanf(
            "%d",&T);
                
            for(int case_num=1;case_num<=T;case_num++)
                {
                    scanf(
            "%d%d",&N,&Q);

                    Build(
            1,1,N);

                    
            while(Q--)
                    {
                        
            int x,y,z;
                        scanf(
            "%d%d%d",&x,&y,&z);
                        Modify(
            1,x,y,z);
                    }

                    printf(
            "Case %d: The total value of the hook is %d.\n",case_num,tree[1].sum);
                }

                
            return 0;
            }
            posted on 2011-07-31 09:24 lee1r 閱讀(346) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 題目分類:數(shù)據(jù)結(jié)構(gòu)
            久久影视综合亚洲| 久久精品国产男包| 人妻精品久久久久中文字幕69 | 亚洲精品乱码久久久久久蜜桃不卡| 久久99热精品| 91久久成人免费| 久久精品人人做人人爽电影| 无码国内精品久久人妻蜜桃| 国产精品一久久香蕉国产线看观看 | 99久久精品久久久久久清纯| 久久久久亚洲精品天堂久久久久久 | 91精品日韩人妻无码久久不卡 | 一本久久综合亚洲鲁鲁五月天| 久久精品国产亚洲av麻豆图片| 麻豆一区二区99久久久久| 99久久www免费人成精品| 国产高潮国产高潮久久久| 亚洲伊人久久成综合人影院 | 久久99国产精品久久99| 亚洲另类欧美综合久久图片区| 亚洲国产日韩欧美综合久久| 欧美久久久久久| 久久人人爽人人爽人人片AV麻烦| 久久久久久国产a免费观看不卡| 国产成人精品三上悠亚久久| 精品久久人人做人人爽综合| 精品久久久久久国产| 久久青青色综合| 久久最新免费视频| 久久精品二区| 久久久久综合中文字幕| 91久久精品无码一区二区毛片| 久久婷婷五月综合色奶水99啪| 亚洲国产成人久久笫一页| 精品无码久久久久国产| 久久精品国产亚洲av麻豆图片| 亚洲国产精品无码久久一区二区| 久久久久人妻精品一区三寸蜜桃| 久久婷婷国产麻豆91天堂| 精品久久久久久无码免费| AV无码久久久久不卡蜜桃|