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

隨筆 - 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>
            日韩一区二区精品| 国产精品卡一卡二卡三| 99re亚洲国产精品| a4yy欧美一区二区三区| 亚洲精品一区二区三| 亚洲福利av| 亚洲黄色一区| 日韩一级在线| 亚洲免费在线看| 久久综合给合久久狠狠狠97色69| 久久男人资源视频| 欧美精品 国产精品| 欧美先锋影音| 国产又爽又黄的激情精品视频| 国语自产偷拍精品视频偷| 亚洲国产欧美日韩| 亚洲夜晚福利在线观看| 欧美在线视频播放| 欧美大尺度在线| 一区二区欧美日韩| 欧美一区1区三区3区公司| 免费成人你懂的| 国产精品久久久久久久久久妞妞| 国产一区二区三区久久久久久久久| 亚洲国产美女| 欧美在线视频二区| 国产精品视频精品| 欧美美女bb生活片| 久久国产精品久久久久久电车| 久久影院亚洲| 国产精品私人影院| 亚洲精品亚洲人成人网| 久久国产精品99国产| 亚洲国产毛片完整版 | 国产精品影音先锋| 亚洲成人在线观看视频| 亚洲一区二区在线看| 免播放器亚洲一区| 一区二区三区视频免费在线观看| 久久久久网站| 国产日本亚洲高清| 一区二区三区日韩在线观看| 欧美不卡视频一区| 性感少妇一区| 国产精品欧美风情| 在线视频你懂得一区| 欧美激情亚洲激情| 久久久精品视频成人| 国产亚洲欧美另类一区二区三区| 亚洲视频久久| 亚洲三级网站| 欧美理论在线播放| 亚洲激情中文1区| 欧美成黄导航| 久久夜色精品国产噜噜av| 国产欧美日韩综合一区在线播放 | 一本色道久久综合亚洲91| 欧美88av| 玖玖玖国产精品| 伊人一区二区三区久久精品| 久久男人资源视频| 久久国产精品久久久久久| 国产农村妇女精品| 欧美一二三区精品| 亚洲欧美综合网| 国产亚洲精品一区二555| 久久久女女女女999久久| 欧美综合国产| 在线观看欧美激情| 亚洲电影专区| 欧美日韩国语| 午夜精品视频在线| 午夜精品久久久久影视| 国产精品午夜久久| 久久精品亚洲一区| 久久久噜噜噜久久久| 精品999在线观看| 欧美精品一区三区在线观看| 老牛嫩草一区二区三区日本 | 亚洲一区二区三区在线播放| aa级大片欧美三级| 国产精品美女久久久| 久久精品二区三区| 久久精品国产一区二区电影| 亚洲第一精品福利| 亚洲欧洲精品一区| 国产精品日日摸夜夜添夜夜av| 欧美一区二区三区啪啪| 久久精品五月婷婷| 99av国产精品欲麻豆| 一区二区三区四区五区在线| 国产精品永久| 亚洲第一中文字幕| 欧美日韩另类丝袜其他| 欧美一区二区免费| 久久综合给合| 亚洲在线日韩| 母乳一区在线观看| 亚洲午夜91| 欧美一区二区三区在线免费观看| 在线电影欧美日韩一区二区私密| 亚洲人成7777| 国产一区二区三区在线免费观看 | 亚洲国产mv| 国产伦精品一区| 亚洲人成高清| 一色屋精品视频在线观看网站| 亚洲毛片一区| 一区二区亚洲| 亚洲欧美综合网| 亚洲免费黄色| 久久精品一区四区| 小嫩嫩精品导航| 欧美福利精品| 欧美成人高清视频| 国产麻豆精品久久一二三| 亚洲人成绝费网站色www| 好吊成人免视频| 亚洲专区免费| 亚洲网站在线播放| 欧美另类人妖| 欧美成人综合在线| 一区国产精品| 欧美一区视频在线| 久久不射2019中文字幕| 欧美午夜视频网站| 亚洲毛片一区| 一本久久知道综合久久| 另类国产ts人妖高潮视频| 久久久之久亚州精品露出| 国产精品私拍pans大尺度在线| 一区二区高清视频| 日韩天堂av| 欧美另类亚洲| 亚洲精选国产| 亚洲少妇中出一区| 欧美日韩国产综合视频在线观看| 欧美r片在线| 亚洲视频在线观看三级| 欧美日韩二区三区| 亚洲国产精品久久久久秋霞蜜臀| 在线欧美影院| 久久婷婷av| 美女视频黄免费的久久| 在线观看亚洲视频啊啊啊啊| 久久久91精品国产| 蜜桃久久av| 亚洲精品影视在线观看| 欧美韩日精品| 99视频在线精品国自产拍免费观看| 日韩午夜高潮| 欧美日韩一区二区三区四区在线观看| 亚洲日本成人女熟在线观看| 99这里只有久久精品视频| 欧美亚韩一区| 欧美一区在线视频| 欧美激情乱人伦| 一区二区三区高清在线| 国产精品卡一卡二卡三| 久久黄色小说| 亚洲精品久久久蜜桃| 亚洲欧美自拍偷拍| 国产综合亚洲精品一区二| 免费在线观看精品| 一个色综合导航| 麻豆精品视频在线观看| 亚洲精品综合精品自拍| 国产精品美女久久久久久久| 久久久久久久高潮| 夜夜狂射影院欧美极品| 久久一区视频| 亚洲在线电影| 亚洲国产综合在线| 国产麻豆9l精品三级站| 欧美freesex8一10精品| 亚洲欧美国产日韩中文字幕| 欧美激情亚洲| 久久美女性网| 亚洲永久免费视频| 亚洲国产毛片完整版| 国产日韩欧美不卡| 欧美日韩午夜精品| 久久婷婷麻豆| 亚洲欧美日韩人成在线播放| 亚洲国产成人精品久久| 久久国产精品一区二区三区四区| 亚洲精品一区二区网址| 国产综合亚洲精品一区二| 欧美日韩精品不卡| 美女黄网久久| 久久精品国产第一区二区三区最新章节 | 日韩一级在线观看| 美乳少妇欧美精品| 欧美一区视频在线| 亚洲一区二区欧美| 亚洲精品中文字幕女同| 激情婷婷欧美| 国产一二三精品| 国产精品日本一区二区| 欧美日韩精品一区二区天天拍小说|