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

隨筆 - 97, 文章 - 22, 評論 - 81, 引用 - 0
數據加載中……

Pku 3468 A Simple Problem With Integers(線段樹)

 

/*

很早以前著手的題,采用了和Pku 2528 的做法做,可惜一直超時,原因是這題如果覆蓋次數一多,
可能最后真正被完全覆蓋的區間可能就沒了,是的查詢的時候全部結點都需要遍歷,使得
原來O(log(n))可以解決的問題退化為O(n),金工實習和匡劍兄一起,于是決定請教一下他,經過匡劍兄的指點,
終于明白了,一共維護兩個域,一個是當前結點的增量值,另外一個是以該結點為根的總和,(注:
祖先的分數不算在內)
那么一共兩個操作:插入和詢問可以這樣:
插入:到達尾部結點時將增量加在該結點上,并且把該區間總增量返還給它父親,一直到根
詢問:一路走下去,并且將父親的增量按權值分配給它的兒子,最后回溯。如此一來,插入和詢問都是O(log(n))
*/

#include 
<iostream>

using namespace std;

__int64 tree[
2000010];
__int64 inc[
2000010];
bool flag[2000010];

__int64 a[
100010];
int n, m;
int i;

__int64 Build(
int p, int l, int r) {
    
if(l == r) {
        tree[p] 
= a[l];
        
return tree[p];
    }

    
int mid = (l + r) / 2;
    tree[
2*p] = Build(2*p, l, mid);
    tree[
2*p+1= Build(2*p+1, mid+1, r);
    
return tree[2*p] + tree[2*p+1];
}


__int64 Query(
int p, int s, int e, int l, int r) {
    
int mid = (l + r) / 2;
    __int64 temp 
= 0;

    
if(s == l && e == r) {
        
return tree[p];
    }


    temp 
= (__int64)(e-s+1)*inc[p];

    
if(e <= mid) {
        
return Query(2*p, s, e, l, mid) + temp;
    }
else if(mid + 1 <= s) {
        
return Query(2*p+1, s, e, mid+1, r) + temp;
    }
else {    
        
return Query(2*p, s, mid, l, mid) + Query(2*p+1, mid+1, e, mid+1, r) + temp;
    }

}


__int64 Insert(
int p, int s, int e, int l, int r, __int64 value) {
    
    
if(s == l && e == r) {
        inc[p] 
+= value;
        tree[p] 
+= value * (r - l + 1);
        
return value * (r - l + 1);
    }


    
int mid = (l + r) / 2;
    __int64 buf 
= 0;


    
if(e <= mid) {
        buf 
+= Insert(2*p, s, e, l, mid, value);
    }
else if(mid + 1 <= s) {
        buf 
+= Insert(2*p+1, s, e, mid+1, r, value);
    }
else {
        buf 
+= Insert(2*p, s, mid, l, mid, value);
        buf 
+= Insert(2*p+1, mid+1, e, mid+1, r, value);
    }

    tree[p] 
+= buf;
    
return buf;
}


int main() {

    
int i, x, y;
    __int64 z;
    
char str[5];
    
while(scanf("%d %d"&n, &m) != EOF) {
        
for(i = 1; i <= n; i++{
            scanf(
"%I64d"&a[i]);
        }

        tree[
1= Build(11, n);
        memset(inc, 
0sizeof(inc));
        
while(m --{
            scanf(
"%s", str);
            
if(str[0== 'Q'{
                scanf(
"%d %d"&x, &y);
                printf(
"%I64d\n", Query(1, x, y, 1, n) );
            }
else {
                scanf(
"%d %d %I64d"&x, &y, &z);
                tree[
1= Insert(1, x, y, 1, n, z);
            }

        }

    }

    
return 0;
}

posted on 2009-04-07 16:31 英雄哪里出來 閱讀(641) 評論(0)  編輯 收藏 引用 所屬分類: ACM

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲午夜精品国产| 亚洲一区二区三区激情| 麻豆成人在线观看| 久久久精品日韩| 久久国产一区二区三区| 性欧美xxxx大乳国产app| 亚洲综合丁香| 午夜精品区一区二区三| 欧美在线高清| 久久人人97超碰人人澡爱香蕉| 欧美诱惑福利视频| 久久香蕉国产线看观看av| 免费成人黄色片| 欧美午夜免费影院| 国产亚洲欧美色| 亚洲人体偷拍| 午夜精品久久久久久久男人的天堂| 欧美在现视频| 亚洲第一精品影视| 一本久道久久综合狠狠爱| 午夜精品久久久久99热蜜桃导演| 久久久久久综合网天天| 欧美三级午夜理伦三级中文幕 | 欧美成年人视频网站| 欧美精选一区| 国产一区91| 一区二区三区四区国产| 久久精品男女| 9色精品在线| 久久在线免费视频| 国产精品国产三级国产a| 国产亚洲免费的视频看| 91久久嫩草影院一区二区| 亚洲女性裸体视频| 久久久久九九视频| 一区二区三区四区五区视频| 欧美一区二区高清| 免费精品99久久国产综合精品| 欧美精品色网| 国产欧美一区二区三区久久| 伊人久久成人| 中文av一区二区| 久久婷婷久久| 一本不卡影院| 亚洲一区二区三区精品动漫| 欧美中文字幕精品| 欧美劲爆第一页| 韩日在线一区| 中文有码久久| 免费在线播放第一区高清av| aa日韩免费精品视频一| 久久久99爱| 亚洲成人在线网| 洋洋av久久久久久久一区| 欧美一区二区三区在线观看视频 | 久久综合影视| 欧美日韩在线一二三| 狠狠色狠色综合曰曰| 一区二区久久久久| 久久精品一区蜜桃臀影院| 亚洲精品久久久一区二区三区| 欧美一区观看| 欧美视频一区二区三区在线观看 | 亚洲一级黄色| 欧美日本免费一区二区三区| 欧美韩国日本综合| 亚洲欧洲三级电影| 亚洲免费激情| 亚洲一区二区三区免费视频| 久久久久久有精品国产| 99re在线精品| 欧美福利视频一区| 亚洲丶国产丶欧美一区二区三区| 亚洲欧美中日韩| 日韩午夜黄色| 欧美日韩精品一本二本三本| 亚洲国产婷婷香蕉久久久久久99 | 欧美1区2区3区| 国内精品视频在线观看| 欧美一级二区| 亚洲色在线视频| 欧美三级第一页| 在线一区欧美| 亚洲精品人人| 欧美揉bbbbb揉bbbbb| 国产精品99久久不卡二区| 亚洲日韩视频| 欧美日韩精品久久| 99精品视频免费全部在线| 久久久久久久综合狠狠综合| 亚洲人线精品午夜| 久久激情网站| 国产精品午夜在线观看| 亚洲欧美日韩天堂一区二区| 亚洲一区美女视频在线观看免费| 国产精品每日更新在线播放网址| 亚洲女人小视频在线观看| 亚洲性视频网址| 国产午夜精品麻豆| 久久综合久久美利坚合众国| 蜜桃久久av| 亚洲网站视频福利| 亚洲综合日韩在线| 媚黑女一区二区| 久久综合网络一区二区| 亚洲欧美综合v| 含羞草久久爱69一区| 亚洲第一黄色| 国产精品www网站| 一区二区三区色| 亚洲精品免费网站| 国产精品一区二区三区四区五区| 亚洲淫性视频| 欧美永久精品| 99精品国产高清一区二区 | 亚洲专区免费| 在线观看亚洲a| 99v久久综合狠狠综合久久| 国产精品日韩精品欧美在线 | 欧美国产激情二区三区| 欧美日本国产在线| 久久精品免视看| 欧美黄污视频| 久久久精品日韩| 欧美日韩久久不卡| 久久一区激情| 国产精品美女黄网| 免费人成网站在线观看欧美高清| 欧美午夜不卡在线观看免费 | 亚洲国产天堂久久综合| 免费成人高清| 99综合在线| 欧美中文在线视频| 亚洲尤物精选| 欧美成年人网站| 久久久久久久久蜜桃| 欧美三级小说| 亚洲大胆av| 国内自拍一区| 亚洲一级电影| 亚洲一级二级| 欧美女主播在线| 欧美福利视频在线| 国产一区二区三区无遮挡| 99日韩精品| 999在线观看精品免费不卡网站| 中文久久精品| 在线精品一区二区| 亚洲伦理一区| 1024国产精品| 久久精品1区| 久久久中精品2020中文| 国产精品亚洲一区| 在线综合欧美| 亚洲一区二区视频在线观看| 欧美精品成人| 亚洲精品三级| 中文一区二区在线观看| 欧美日韩国产一区二区三区地区| 亚洲国产精品一区二区尤物区| 在线观看精品| 久久综合久久综合九色| 欧美高清视频一区二区三区在线观看 | 久久激情视频久久| 久久精品理论片| 国产欧美日韩中文字幕在线| 日韩视频免费在线| 欧美激情影院| 另类图片综合电影| 尤物网精品视频| 另类图片国产| 亚洲日本欧美天堂| 99精品视频免费全部在线| 欧美国产综合| 在线视频欧美一区| 欧美一区视频| 国产有码在线一区二区视频| 久久精品在线观看| 欧美国产综合一区二区| 亚洲日韩第九十九页| 欧美日韩午夜在线| 亚洲在线网站| 欧美一级淫片aaaaaaa视频| 国产精品免费福利| 久久久久国产一区二区| 国产美女精品在线| 久久精品成人欧美大片古装| 欧美成人自拍视频| 在线一区二区视频| 国产一区91| 欧美激情一区二区三区不卡| 一区二区三区 在线观看视频| 性一交一乱一区二区洋洋av| 国产一区二区中文| 欧美日本在线| 99视频一区二区| 久久久久久久一区二区| 日韩视频在线你懂得| 国产欧美一区二区三区久久人妖| 久久网站免费|