• <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>

            糯米

            TI DaVinci, gstreamer, ffmpeg
            隨筆 - 167, 文章 - 0, 評論 - 47, 引用 - 0
            數據加載中……

            POJ 1990 MooFest 樹狀數組

            思路:
            開四個樹狀數組。。
            arr_x,arr_y,arr_xy,arr_cnt
            分別統計y軸下:x的和、y的和、x*y的和、點的個數。
            把點按照x排序,x越大的點出現得越晚。
            從前往后推,每出現一個新的點的時候:
            Step1,將該點加入到四個數組中。
            Step2,對于高于它的點,面積增量為 x*sum(y) - sum(x*y)。
            Step3,對于低于它的點,面積增量為 sum(y) * (cnt * x - sum(x))
            最終得出結果。復雜度O(NlgN)。代碼 63ms。

            注意:
            需要用int64保存數組元素

            #include <stdio.h>

            #define MAX_X 20032
            #define MAX_Y 20032

            int cow[MAX_X], left, top, N;
            __int64 arr_x[MAX_Y], arr_y[MAX_Y], arr_xy[MAX_Y], arr_cnt[MAX_Y];

            __inline 
            int lowbit(int i)
            {
                
            return i & (i ^ (i - 1));
            }


            __inline __int64 sum(__int64 
            *arr, int i)
            {
                __int64 s;
                
                
            for (s = 0; i; i -= lowbit(i))
                    s 
            += arr[i];
                
            return s;
            }


            __inline 
            void insert(__int64 *arr, int i, __int64 val)
            {
                
            for (; i <= top; i += lowbit(i))
                    arr[i] 
            += val;
            }


            int main()
            {
                
            int i, x, y;
                __int64 s, sx, sy, sxy, c;

                freopen(
            "e:\\test\\in.txt""r", stdin);

                scanf(
            "%d"&N);
                left 
            = MAX_X;
                
            for (i = 0; i < N; i++{
                    scanf(
            "%d%d"&y, &x);
                    
            if (x < left)
                        left 
            = x;
                    
            if (y > top)
                        top 
            = y;
                    cow[x] 
            = y;
                }


                s 
            = 0;
                x 
            = left - 1;
                
            for (i = 0; i < N; i++{
                    
            for (x++!cow[x]; x++);
                    y 
            = cow[x];
                    insert(arr_x, y, x);
                    insert(arr_y, y, y);
                    insert(arr_xy, y, x 
            * y);
                    insert(arr_cnt, y, 
            1);
                    c 
            = sum(arr_cnt, y - 1);
                    sx 
            = sum(arr_x, y - 1);
                    s 
            += c*x*- sx*y;
                    sy 
            = sum(arr_y, top) - sum(arr_y, y - 1);
                    sxy 
            = sum(arr_xy, top) - sum(arr_xy, y - 1);
                    s 
            += x*sy - sxy;
                }


                printf(
            "%I64d\n", s);

                
            return 0;
            }

            posted on 2010-03-14 17:39 糯米 閱讀(395) 評論(0)  編輯 收藏 引用 所屬分類: POJ

            尹人香蕉久久99天天拍| 99热热久久这里只有精品68| 亚洲狠狠综合久久| 国产福利电影一区二区三区,免费久久久久久久精 | 偷偷做久久久久网站| 亚洲色大成网站WWW久久九九| 国产精品久久成人影院| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区| 精品久久久久中文字幕一区| 性欧美大战久久久久久久久 | 久久亚洲私人国产精品| 亚州日韩精品专区久久久| 99久久精品免费| 乱亲女H秽乱长久久久| 麻豆久久| 国产精品久久久久蜜芽| 99久久国产主播综合精品| 色88久久久久高潮综合影院| 久久久精品日本一区二区三区 | AV无码久久久久不卡蜜桃| 99久久无色码中文字幕人妻| 亚洲国产精品久久久久| 久久人人爽人人爽人人片av麻烦| 欧美精品福利视频一区二区三区久久久精品 | 精品熟女少妇av免费久久| 综合久久一区二区三区 | 亚洲国产日韩欧美久久| 久久国产精品国语对白| 精品水蜜桃久久久久久久| 日韩亚洲欧美久久久www综合网 | 亚洲狠狠婷婷综合久久蜜芽| 亚洲中文字幕伊人久久无码 | 99精品国产99久久久久久97 | 久久久久久免费一区二区三区| 久久夜色精品国产噜噜麻豆| 伊人久久大香线蕉av不变影院| 免费一级做a爰片久久毛片潮| 久久se精品一区二区影院 | 伊人久久大香线焦AV综合影院| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 久久精品一本到99热免费|