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

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

PKU 3468 A Simple Problem with Integers

題目鏈接:http://poj.org/problem?id=3468

/*
題意:
    給定一個長度為N(N <= 100000)的數列Si,緊接著Q條詢問,詢問格式如下:
"C a b c" 表示對 Aa, Aa+1,  , Ab 的值都加上一個c(-10000 <= c <= 10000)
"Q a b" 表示求 Aa, Aa+1,  , Ab 的和。

解法:
線段樹

思路:
    線段樹的經典題目了,主要是一個lazy思想。這題要求求和,所以我們給線段樹
的每個結點添加一個sum字段和一個lazy-tag標記(等下來討論這個標記的作用)。
    每次在區間[a, b]插入一個c的時候,如果更新到葉子節點,那么無疑是nlogn的,
比純暴力還要不值,所以添加lazy標記是為了延遲更新,使得每次插入和詢問都控制
在log(n)。在插入時,只在[a, b]完全覆蓋當前結點區間時,才把c的值累加給lazy-
tag,sum的值也加上當前 當前結點區間長度*c。如果沒有完全覆蓋,則繼續遞歸左右
兒子,并且如果當前結點存在lazy標記,那么將它的值累加到左右兒子的lazy標記上,
并且讓左右兒子更新sum值,最后當前結點的lazy標記清零。注意遞歸完畢時需要更新
當前結點的sum值,因為左右兒子的sum值的改變勢必會影響到當前結點。詢問時也一
樣,每次將當前結點的lazy標記傳遞給兒子。當遞歸到區間完全覆蓋的時候返回,這樣
詢問也是log(n)的。
*/

#include 
<iostream>

using namespace std;

#define ll __int64

#define maxn 100200

struct Tree {
    
int idx;
    
int l, r;
    ll sum;      
// 當前區間的和
    ll lazyTag;  // lazy 標記

    
int GetMid() {
        
return (l + r) >> 1;
    }


    
int GetLen() {
        
return r - l + 1;
    }


    
void ClearTag() {
        
if(lazyTag) {
            T[idx
<<1].lazyTag   += lazyTag;
            T[idx
<<1|1].lazyTag += lazyTag;
            
            T[idx
<<1].sum       += lazyTag * T[idx<<1].GetLen();
            T[idx
<<1|1].sum     += lazyTag * T[idx<<1|1].GetLen();
            
            lazyTag 
= 0;
        }

    }

}
T[4*maxn];

int n, m;
int v[maxn];

void Build(int p, int l, int r) {
    T[p].l 
= l; T[p].r = r;
    T[p].idx 
= p; T[p].lazyTag = 0;
    
if(l == r) {
        T[p].sum 
= v[l];
        
return ;
    }

    
int mid = (l + r) >> 1;
    Build(p
<<1, l, mid);
    Build(p
<<1|1, mid+1, r);
    T[p].sum 
= T[p<<1].sum + T[p<<1|1].sum;
}


void Insert(int p, int l, int r, ll v) {
    
if(l <= T[p].l && T[p].r <= r) {
        T[p].lazyTag 
+= v;
        T[p].sum 
+= v * T[p].GetLen();
        
return ;
    }

    T[p].ClearTag();
    
int mid = T[p].GetMid();
    
if(l <= mid) {
        Insert(p
<<1, l, r, v);
    }

    
if(r >= mid + 1{
        Insert(p
<<1|1, l, r, v);
    }

    T[p].sum 
= T[p<<1].sum + T[p<<1|1].sum;
}


ll Query(
int p, int l, int r) {
    
if(l <= T[p].l && T[p].r <= r) {
        
return T[p].sum;
    }

    T[p].ClearTag();
    
int mid = T[p].GetMid();
    ll v 
= 0;
    
if(l <= mid) {
        v 
+= Query(p<<1, l, r);
    }

    
if(r >= mid + 1{
        v 
+= Query(p<<1|1, l, r);
    }

    
return v;
}


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

        Build(
11, n);
        
while(m--{
            scanf(
"%s", str);
            
if(!strcmp(str, "Q")) {
                scanf(
"%d %d"&x, &y);
                ll val 
= Query(1, x, y);
                printf(
"%I64d\n", val);
            }
else {
                scanf(
"%d %d %d"&x, &y, &z);
                Insert(
1, x, y, z);
            }

        }

    }

    
return 0;
}

posted on 2011-03-30 11:16 英雄哪里出來 閱讀(1321) 評論(0)  編輯 收藏 引用 所屬分類: 線段樹

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产一二三精品| 久久久久成人网| 欧美性片在线观看| 欧美大片91| 久久精品视频99| 久久综合五月| 欧美激情一区二区三区在线视频| 久久久久国产精品人| 久久综合狠狠综合久久综青草| 久久在线观看视频| 免费在线国产精品| 欧美日韩蜜桃| 国产一区二区三区奇米久涩 | 欧美一区亚洲二区| 久久久福利视频| 欧美国产大片| 国产精品羞羞答答xxdd| 亚洲电影网站| 亚洲——在线| 久久在线播放| 日韩一级黄色片| 欧美一区二区三区视频免费| 免费日本视频一区| 国产老肥熟一区二区三区| 在线免费观看成人网| 亚洲伊人观看| 女人天堂亚洲aⅴ在线观看| 在线一区二区三区做爰视频网站| 性娇小13――14欧美| 欧美女主播在线| 一区二区三区在线视频观看| 亚洲图片欧美日产| 欧美激情精品久久久久久黑人 | 国产婷婷一区二区| 日韩亚洲欧美中文三级| 久久噜噜亚洲综合| 一区二区三区三区在线| 蜜月aⅴ免费一区二区三区 | 亚洲七七久久综合桃花剧情介绍| 午夜精品久久久久久久久久久久久 | 免费观看不卡av| 国产日韩欧美成人| 亚洲网站在线| 亚洲欧洲一级| 欧美一二三视频| 欧美三日本三级少妇三99| 欧美韩日视频| 国产精品免费一区二区三区观看| 亚洲国产另类精品专区 | 欧美一区二区三区在线视频 | 久久久久一区二区| 亚洲午夜一区| 国产精品成人免费| 在线一区日本视频| 亚洲激情成人在线| 久久综合九色九九| 在线观看日产精品| 免费国产一区二区| 久久精品国产精品| 狠狠综合久久| 老牛嫩草一区二区三区日本| 亚洲欧美视频在线观看视频| 国产精品伦一区| 性欧美8khd高清极品| 一区二区久久久久久| 欧美日韩1区| 中文一区二区| 亚洲视频在线观看| 国产精品国产一区二区| 亚洲欧美综合一区| 午夜综合激情| 一区免费观看| 亚洲国产日韩美| 欧美日韩国产二区| 亚洲一区区二区| 亚洲欧美一区二区原创| 韩国成人精品a∨在线观看| 噜噜噜在线观看免费视频日韩| 久久爱另类一区二区小说| 亚洲第一福利视频| 亚洲精品视频免费| 国产精品欧美在线| 久久综合色播五月| 欧美精品在线免费观看| 亚洲自拍偷拍视频| 久久精品一区二区三区不卡牛牛| 亚洲国产精品精华液2区45| 亚洲精品一区二区三区av| 国产精品v亚洲精品v日韩精品| 性伦欧美刺激片在线观看| 久久露脸国产精品| 亚洲深爱激情| 久久精品视频亚洲| 宅男噜噜噜66一区二区66| 亚洲一区在线免费观看| 在线日韩欧美| 中文国产成人精品| 亚洲成色999久久网站| 一区二区三区**美女毛片 | 一区二区三区色| 久久9热精品视频| 99国产精品| 性做久久久久久| 99视频超级精品| 欧美一区影院| 黄色日韩精品| 亚洲精品视频在线播放| 国产偷国产偷精品高清尤物| 亚洲国产成人av| 国产精品一区二区女厕厕| 欧美高清自拍一区| 国产乱人伦精品一区二区 | 欧美国产日韩一二三区| 欧美午夜精品理论片a级大开眼界| 久久久久久久久久码影片| 欧美日本韩国在线| 美女露胸一区二区三区| 国产精品综合色区在线观看| 亚洲精品男同| 亚洲国产人成综合网站| 欧美一区观看| 亚洲欧美国产一区二区三区| 欧美国产在线视频| 麻豆精品在线视频| 国产一区二区精品久久91| 一区二区三区国产| 日韩写真在线| 欧美激情aⅴ一区二区三区| 久久综合中文| 国产综合在线视频| 香蕉亚洲视频| 欧美在线视频在线播放完整版免费观看| 欧美日韩国产一区二区| 亚洲精品乱码久久久久久黑人| 亚洲高清一区二| 久久久xxx| 亚洲大片一区二区三区| 亚洲日本国产| 欧美激情一区二区三区高清视频| 蜜桃av一区二区三区| 在线看视频不卡| 欧美岛国在线观看| 亚洲精品免费一区二区三区| 中文国产一区| 国产精品羞羞答答| 小嫩嫩精品导航| 久久久精品国产免大香伊| 国产综合色在线视频区| 老司机午夜精品视频| 亚洲欧洲久久| 亚洲特级毛片| 国产欧美在线视频| 久久久久久久久久久成人| 欧美高清成人| 亚洲在线播放电影| 久久亚洲精品中文字幕冲田杏梨 | 欧美性猛交99久久久久99按摩| 亚洲精品日韩精品| 午夜在线播放视频欧美| 国产亚洲精品资源在线26u| 欧美一区在线看| 欧美粗暴jizz性欧美20| 亚洲精品免费一区二区三区| 欧美日韩国产色视频| 亚洲欧美日本精品| 久久久久久久综合狠狠综合| 午夜精品电影| 亚洲日本视频| 欧美性大战久久久久| 欧美一级午夜免费电影| 欧美成人午夜激情视频| 一区二区三区鲁丝不卡| 国产欧美日韩91| 免费黄网站欧美| 亚洲一区二区伦理| 免费观看国产成人| 在线亚洲伦理| 精品不卡在线| 国产精品成人观看视频国产奇米| 久久不射2019中文字幕| 99re热精品| 免费成人网www| 午夜免费在线观看精品视频| 亚洲国产精品成人| 国产欧美日韩三级| 欧美日韩国产成人在线91| 欧美自拍偷拍午夜视频| 一区二区免费在线播放| 亚洲激情第一区| 蜜臀a∨国产成人精品| 午夜精品久久久久久久男人的天堂 | 亚洲国产精品一区二区www| 国产精品久久久久久久7电影 | 国产精品推荐精品| 欧美**字幕| 久久久精品欧美丰满| 亚洲欧美在线一区| 一本色道久久综合亚洲精品婷婷 | 一本色道久久88综合日韩精品| 国产偷久久久精品专区|