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

隨筆 - 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 英雄哪里出來 閱讀(643) 評論(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>
            国产日韩欧美中文| 国产亚洲精久久久久久| 一区二区三区中文在线观看 | 国产精品女人毛片| 亚洲一区二区视频在线| 99精品热6080yy久久| 欧美三日本三级少妇三2023| 日韩系列欧美系列| 一区二区三区.www| 国产亚洲一区在线播放| 久久色在线播放| 免费成人在线观看视频| 亚洲每日更新| 亚洲特色特黄| 黄网站免费久久| 亚洲高清毛片| 国产精品极品美女粉嫩高清在线 | 在线视频欧美日韩精品| 亚洲伊人第一页| 在线看欧美日韩| 日韩一级片网址| 国产视频亚洲精品| 欧美国产日韩视频| 国产精品高潮粉嫩av| 久久综合精品一区| 欧美日韩高清一区| 久久女同互慰一区二区三区| 蜜臀久久99精品久久久久久9 | 中文精品视频| 久久精品国产v日韩v亚洲| 亚洲欧洲一区二区三区在线观看| 亚洲美女视频在线免费观看| 国产欧美日韩精品一区| 亚洲高清激情| 国内久久婷婷综合| 夜夜嗨av一区二区三区网站四季av| 国产日韩在线视频| 日韩亚洲欧美一区二区三区| 国产一区二区三区四区| 亚洲蜜桃精久久久久久久 | 久久综合九色综合欧美就去吻| 99在线热播精品免费99热| 午夜在线播放视频欧美| 99精品99| 狂野欧美一区| 久久偷窥视频| 国产精品久久一卡二卡| 亚洲国产一区二区在线| 国产网站欧美日韩免费精品在线观看 | 国产精品福利片| 亚洲第一区在线观看| 国产日韩欧美综合| 亚洲无毛电影| 一区二区三区久久网| 欧美~级网站不卡| 美脚丝袜一区二区三区在线观看 | 午夜精彩视频在线观看不卡 | 激情亚洲一区二区三区四区| 亚洲美女av电影| 亚洲看片免费| 欧美不卡视频一区发布| 欧美国产一区视频在线观看| 国产一区视频网站| 性一交一乱一区二区洋洋av| 亚洲欧美一区二区激情| 欧美日韩综合在线免费观看| 亚洲人www| 亚洲精选中文字幕| 欧美激情一区二区三区在线视频观看 | 亚洲啪啪91| 麻豆精品视频| 亚洲第一区在线| 日韩视频一区二区三区在线播放免费观看| 久久精品一二三区| 久久亚洲国产成人| 亚洲第一视频网站| 欧美成人a视频| 亚洲理论电影网| 亚洲一区在线看| 国产视频亚洲| 久久男人资源视频| 亚洲电影网站| 亚洲一区久久久| 国产精品永久| 久久久综合网站| 亚洲国产经典视频| 亚洲天堂网在线观看| 国产精品系列在线播放| 久久成人人人人精品欧| 欧美激情2020午夜免费观看| 99精品视频免费| 国产女优一区| 噜噜噜噜噜久久久久久91| 亚洲欧洲日夜超级视频| 亚洲一区二区三区视频| 国产午夜精品在线| 欧美成人一区二区三区在线观看| 99精品视频免费在线观看| 欧美一区二区三区在线观看| 在线日韩精品视频| 国产精品va在线| 久久免费99精品久久久久久| 亚洲国产成人精品女人久久久| 一区二区三区色| 激情久久久久久久| 欧美午夜无遮挡| 久久久久9999亚洲精品| 亚洲美女91| 欧美a级片网站| 午夜亚洲精品| 亚洲乱码精品一二三四区日韩在线| 国产精品高清在线| 欧美bbbxxxxx| 午夜精品一区二区三区电影天堂| 欧美激情女人20p| 久久国内精品视频| 亚洲视频一区二区在线观看| 黄色精品免费| 国产精品亚洲综合久久| 欧美高清视频一二三区| 欧美一级大片在线观看| 99re这里只有精品6| 欧美成人在线影院| 欧美在线啊v一区| 亚洲视频1区2区| 亚洲精品日日夜夜| 亚洲承认在线| 国产专区综合网| 国产精品一区二区在线观看| 欧美日韩免费| 欧美久久视频| 欧美91大片| 另类尿喷潮videofree| 欧美一区二区三区在| 亚洲自拍电影| 在线视频一区观看| 夜夜夜精品看看| 亚洲精品午夜精品| 亚洲国产成人在线视频| 欧美福利一区二区| 欧美大胆成人| 欧美大片在线看免费观看| 老司机免费视频一区二区三区| 欧美一区二区视频在线观看2020| 亚洲中字黄色| 亚洲欧美一区二区三区在线| 国产精品99久久不卡二区| 日韩午夜三级在线| 亚洲最新合集| 亚洲一区二区三区久久| 亚洲一区二区视频在线观看| 亚洲小少妇裸体bbw| 亚洲一区二区三区免费观看| 亚洲小说区图片区| 午夜精品久久久久久久99樱桃 | 午夜精品福利视频| 欧美在线短视频| 欧美一区二区高清在线观看| 亚洲综合欧美| 欧美一区影院| 久色成人在线| 最新亚洲激情| 一区二区日韩免费看| 亚洲一区二区三区四区中文| 亚洲欧美高清| 久久精品国内一区二区三区| 老鸭窝毛片一区二区三区| 欧美精品一区二区视频| 国产精品草草| 狠狠色丁香久久婷婷综合丁香| 亚洲国产mv| 亚洲视频在线视频| 久久久久久穴| 亚洲人成亚洲人成在线观看图片| 日韩网站在线看片你懂的| 亚洲在线第一页| 免费欧美在线| 国产精品免费网站在线观看| 国产亚洲视频在线观看| 亚洲肉体裸体xxxx137| 亚洲欧美中文日韩v在线观看| 久久久久久亚洲精品不卡4k岛国| 亚洲高清在线| 亚洲欧美精品伊人久久| 美女久久网站| 国产伦精品一区二区三区视频黑人| 精品动漫3d一区二区三区| 一区二区欧美日韩视频| 久久国产精品99国产精| 欧美国产一区二区在线观看| 在线亚洲一区观看| 猛干欧美女孩| 国产女精品视频网站免费 | 国产手机视频一区二区| 亚洲欧洲日韩女同| 久久久国产午夜精品| 亚洲日本久久| 久久久爽爽爽美女图片| 国产精品视频福利| 在线视频你懂得一区二区三区|