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

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

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

 

/*

很早以前著手的題,采用了和Pku 2528 的做法做,可惜一直超時,原因是這題如果覆蓋次數(shù)一多,
可能最后真正被完全覆蓋的區(qū)間可能就沒了,是的查詢的時候全部結點都需要遍歷,使得
原來O(log(n))可以解決的問題退化為O(n),金工實習和匡劍兄一起,于是決定請教一下他,經(jīng)過匡劍兄的指點,
終于明白了,一共維護兩個域,一個是當前結點的增量值,另外一個是以該結點為根的總和,(注:
祖先的分數(shù)不算在內(nèi))
那么一共兩個操作:插入和詢問可以這樣:
插入:到達尾部結點時將增量加在該結點上,并且把該區(qū)間總增量返還給它父親,一直到根
詢問:一路走下去,并且將父親的增量按權值分配給它的兒子,最后回溯。如此一來,插入和詢問都是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>
            有码中文亚洲精品| 欧美在线观看一二区| 中文一区在线| 欧美日韩在线视频一区| 日韩午夜在线视频| 午夜精品久久久久影视| 国产一区二区三区高清在线观看| 欧美一级久久久| 模特精品裸拍一区| 9国产精品视频| 国产农村妇女毛片精品久久莱园子 | 欧美中文在线观看国产| 每日更新成人在线视频| 亚洲国产另类精品专区 | 免费欧美日韩| 99精品欧美| 国产婷婷色一区二区三区| 久久精品视频网| 91久久在线观看| 午夜精品国产精品大乳美女| 狠狠色狠狠色综合日日tαg| 欧美精品一区二区三区很污很色的| 亚洲图片欧洲图片av| 免费成人美女女| 亚洲欧美高清| 亚洲欧洲美洲综合色网| 国产精品久久久免费| 久久午夜视频| 亚洲午夜免费视频| 欧美国产免费| 久久精品免费播放| 亚洲乱码精品一二三四区日韩在线 | 日韩一级免费| 美女久久网站| 小处雏高清一区二区三区| 亚洲精品一区二区三区99| 国产一区二区久久久| 欧美日韩伦理在线| 六月天综合网| 久久国产免费看| 亚洲一区精品电影| 亚洲日本中文字幕区| 美国成人直播| 久久精品视频免费| 亚洲欧美日韩直播| 一本色道久久88综合亚洲精品ⅰ | 亚洲女同在线| 日韩网站在线观看| 欧美高清视频一区二区| 久久久久久夜| 久久国产精品毛片| 亚洲一区在线免费| av成人免费在线观看| 亚洲第一精品久久忘忧草社区| 国产欧美一区二区三区另类精品| 欧美人交a欧美精品| 美女精品视频一区| 久久视频一区| 久久免费视频在线观看| 欧美中文字幕视频在线观看| 亚洲在线视频网站| 亚洲视频在线看| 99视频精品全国免费| 亚洲欧洲视频| 91久久在线观看| 亚洲另类春色国产| 亚洲精品综合久久中文字幕| 91久久香蕉国产日韩欧美9色| 欧美成人激情视频| 欧美成年人网站| 欧美成年人视频| 欧美国产大片| 最新国产の精品合集bt伙计| 亚洲激情成人| 亚洲精品三级| 夜夜嗨av色一区二区不卡| 99re6这里只有精品视频在线观看| 亚洲精品一区二区三区99| 亚洲精品在线三区| 一本一本久久a久久精品综合妖精| 99国产精品99久久久久久粉嫩| 99精品国产99久久久久久福利| 99riav1国产精品视频| 一区二区日本视频| 亚洲天堂黄色| 久久riav二区三区| 嫩模写真一区二区三区三州| 欧美理论片在线观看| 欧美日韩国产色综合一二三四| 欧美视频精品一区| 国产精品视频免费在线观看| 国产亚洲一区精品| 亚洲电影免费在线| av不卡在线| 欧美影院视频| 欧美成人午夜激情在线| 亚洲伦理在线| 亚洲欧美一区二区三区在线| 久久九九免费| 欧美日本韩国在线| 国产伦精品一区二区三| 在线观看日韩| 日韩午夜在线电影| 欧美在线影院| 亚洲第一视频网站| 亚洲午夜av| 久久麻豆一区二区| 欧美日韩一区二区视频在线观看| 国产欧美精品| 日韩午夜中文字幕| 久久精品国产精品亚洲| 欧美激情在线有限公司| 亚洲小说春色综合另类电影| 久久久久久久久久久成人| 欧美日韩1区2区3区| 国产一区二区三区四区| 一本色道久久精品| 久久久免费观看视频| 99精品黄色片免费大全| 久久久久国产精品厨房| 欧美午夜电影一区| 在线观看视频欧美| 欧美亚洲系列| 亚洲人精品午夜在线观看| 欧美在线日韩精品| 欧美日韩在线不卡一区| 在线观看视频一区二区欧美日韩| 亚洲一区999| 亚洲国产精品va在看黑人| 性娇小13――14欧美| 欧美日韩一区在线| 亚洲精品国精品久久99热| 久久久久成人网| 国产精品99久久久久久久vr| 女人香蕉久久**毛片精品| 国产午夜精品一区二区三区欧美 | 欧美亚洲网站| 亚洲精选中文字幕| 久久综合狠狠| 国产在线观看一区| 欧美一区二区私人影院日本| 99视频精品| 欧美日韩国产在线看| 亚洲国产精品一区二区第一页 | 亚洲国产一区二区三区a毛片| 午夜精品久久久久久久久| 亚洲人成毛片在线播放| 免费久久99精品国产自在现线| 国产最新精品精品你懂的| 欧美在线你懂的| 亚洲一级在线| 国产精品xxxxx| 亚洲婷婷综合色高清在线| 亚洲激情网站| 欧美激情视频网站| 亚洲免费大片| 亚洲激情在线激情| 欧美激情一区二区三区 | 亚洲伊人久久综合| 亚洲伦理久久| 欧美日本乱大交xxxxx| 99精品欧美一区| 亚洲乱码日产精品bd| 欧美日韩高清一区| 国产精品99久久久久久白浆小说| 亚洲国产欧美一区二区三区同亚洲 | 欧美日韩一卡二卡| 亚洲天堂成人在线观看| 99精品国产高清一区二区| 欧美日韩一级大片网址| 亚洲一区自拍| 午夜精品亚洲| 激情综合色丁香一区二区| 欧美3dxxxxhd| 欧美激情麻豆| 一区二区三区久久久| 99伊人成综合| 国产日韩欧美在线一区| 久久婷婷国产综合国色天香| 巨乳诱惑日韩免费av| 日韩天堂在线观看| 亚洲午夜av电影| 韩国一区电影| 亚洲国产高清一区| 欧美视频精品一区| 久久精品噜噜噜成人av农村| 久久视频精品在线| 一区二区国产在线观看| 亚洲一级影院| 影音先锋中文字幕一区| 亚洲日韩中文字幕在线播放| 国产精品激情av在线播放| 久久久国产精品亚洲一区| 老司机午夜精品| 亚洲在线播放| 久久视频这里只有精品| 夜夜嗨av一区二区三区网页 | 久久久久久久久久久一区| 亚洲精品护士| 亚洲免费在线观看|