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

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

ZJU 2706 Thermal Death of the Universe

題目鏈接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2706


/*
題意:
    給定一個(gè)長度為N(N <= 30000)的數(shù)列Si,緊接著Q條區(qū)間處理,每一條處理的要
求是將給定的區(qū)間內(nèi)的數(shù)字替換成他們的平均值,替換時(shí)如果當(dāng)前數(shù)列的總和比原先
數(shù)列的總和小或者相等時(shí),平均值向上取整,否則向下取整,最后要求輸出處理完的
數(shù)組的每一個(gè)元素。

解法:
線段樹

思路:
    一看到數(shù)據(jù)量就可以首先確定是線段樹了,然后我們來把這題需要求的東西分解
一下,題目中提到當(dāng)前數(shù)列和和原數(shù)列和比較大小,所以首先一個(gè)操作就是區(qū)間求和
,然后將區(qū)間內(nèi)的數(shù)替換成另外一個(gè)數(shù),這就用到了區(qū)間修改,和線段樹的操作完全
吻合。接下來就可以開始設(shè)計(jì)線段樹結(jié)點(diǎn)的域了。其實(shí)這題的思想和pku 3468是大同
小異的,還是lazy思想。每次插入的時(shí)候不更新到葉子結(jié)點(diǎn),在插入?yún)^(qū)間完全覆蓋當(dāng)
前區(qū)間時(shí)就返回,否則將當(dāng)前結(jié)點(diǎn)的lazy標(biāo)記傳遞給左右兒子,并且更新左右兒子的
sum值,注意,這里每次不是累加,因?yàn)槭切薷模灾苯訉?nbsp;sum*左右兒子的區(qū)間長
度 分別賦值給左右兒子即可。遞歸結(jié)束時(shí)更新當(dāng)前結(jié)點(diǎn)的sum值。詢問時(shí)也是相同,
每次傳遞lazy標(biāo)記給兒子。這樣就可以做到詢問和插入都是log(n)。
*/


#include 
<iostream>
#include 
<cstdio>
#include 
<cstring>
using namespace std;

#define maxn 30010
#define inf INT_MIN
#define ll long long

struct Tree {
    
int p, l, r;
    ll sum;
    ll lazy_tag;

    
void ClearTag();

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

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

}
T[4*maxn];

void Tree::ClearTag() {
    
if(lazy_tag) {
        T[p
<<1].lazy_tag    = lazy_tag;
        T[p
<<1|1].lazy_tag  = lazy_tag;
        
        T[p
<<1].sum         = lazy_tag * T[p<<1].GetLen();
        T[p
<<1|1].sum       = lazy_tag * T[p<<1|1].GetLen();
        
        lazy_tag 
= 0;
    }

}


int n, m;
int val[maxn];

void Build(int p, int l, int r) {
    T[p].l 
= l;
    T[p].r 
= r;
    T[p].p 
= p;
    T[p].lazy_tag 
= 0;

    
if(l == r) {
        T[p].sum 
= val[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;
}


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;
}


void Modify(int p, int l, int r, ll val) {
    
if(l <= T[p].l && T[p].r <= r) {
        T[p].lazy_tag 
= val;
        T[p].sum 
= val * T[p].GetLen();
        
return ;
    }

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

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


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


ll Calc(ll val, 
int dn, bool bRoundUp) {
    
if(val >= 0{
        
if(bRoundUp) {
            
return (val + dn - 1/ dn;
        }
else
            
return val / dn;
    }
else {
        val 
= -val;
        
if(bRoundUp) {
            
return -(val / dn);
        }
else {
            
return -((val + dn - 1/ dn);
        }

    }

}


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

        Build(
11, n);
        ll ans 
= T[1].sum;
        
while(m--{
            scanf(
"%d %d"&x, &y);
            ll Sum 
= Query(1, x, y);
            ll all 
= Query(11, n);
            Sum 
= Calc(Sum, y-x+1, all <= ans);
            Modify(
1, x, y, Sum);
        }

        
for(i = 1; i <= n; i++{
            
if(i != 1)
                printf(
" ");
            printf(
"%lld", Query(1, i, i));
        }

        puts(
"\n");
    }

    
return 0;
}

posted on 2011-03-30 11:58 英雄哪里出來 閱讀(1240) 評(píng)論(2)  編輯 收藏 引用 所屬分類: 線段樹

評(píng)論

# re: ZJU 2706 Thermal Death of the Universe  回復(fù)  更多評(píng)論   

某ACM菜鳥,前來串門。。。
2011-03-30 13:10 | coreBugZJ

# re: ZJU 2706 Thermal Death of the Universe  回復(fù)  更多評(píng)論   

@coreBugZJ
同菜~~
2011-03-30 13:31 | 英雄哪里出來
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品五月| 亚洲国产成人精品女人久久久 | 亚洲欧美国产精品桃花| 精品动漫av| 国产美女扒开尿口久久久| 欧美精品观看| 久久影视三级福利片| 欧美一区二区免费观在线| 日韩视频亚洲视频| 亚洲国产导航| 欧美不卡在线| 蜜桃av噜噜一区二区三区| 香蕉久久国产| 亚洲免费网站| 亚洲影视在线| 在线视频欧美日韩| 日韩视频免费观看| 亚洲国产欧美日韩精品| 激情丁香综合| 激情另类综合| 国产综合网站| 韩国av一区二区三区四区| 国产欧美精品一区二区三区介绍| 国产精品久久国产精品99gif| 欧美日本在线播放| 欧美激情精品久久久久久变态| 玖玖国产精品视频| 另类人畜视频在线| 久久久亚洲成人| 久久夜色撩人精品| 快射av在线播放一区| 久久久综合激的五月天| 久久免费国产| 免费h精品视频在线播放| 狼人社综合社区| 你懂的成人av| 欧美理论在线播放| 欧美日韩一区在线观看| 欧美日韩色婷婷| 国产精品激情偷乱一区二区∴| 欧美午夜片在线观看| 国产精品videosex极品| 国产精品一区在线播放| 国产综合色一区二区三区 | 欧美www视频在线观看| 久久免费午夜影院| 免费永久网站黄欧美| 亚洲第一中文字幕| 亚洲精品国产日韩| 亚洲视频精品| 久久成人一区二区| 嫩草国产精品入口| 欧美色欧美亚洲另类七区| 国产精品久久久久久久久搜平片| 国产精品亚洲аv天堂网| 国产一区久久久| 亚洲黄色尤物视频| 亚洲深夜激情| 久久久999| 亚洲国产精品电影在线观看| 亚洲精品在线观看免费| 亚洲永久精品国产| 久久精彩视频| 欧美精品在线看| 国产人成一区二区三区影院| 在线精品国产欧美| 一区二区三区久久| 久久国产精品久久国产精品| 欧美国产三区| 亚洲一级黄色av| 麻豆国产va免费精品高清在线| 欧美日韩国产美| 国产综合av| 亚洲视频图片小说| 久久久欧美精品| 亚洲全黄一级网站| 欧美一区二区三区在线免费观看| 欧美a级片网| 国产欧美日韩不卡| 亚洲精品一区中文| 久久久av毛片精品| 亚洲每日在线| 久久久亚洲欧洲日产国码αv| 欧美日韩综合| 亚洲高清视频中文字幕| 午夜精品视频网站| 亚洲国产婷婷香蕉久久久久久| 亚洲男人第一av网站| 欧美暴力喷水在线| 国产一区二区三区av电影| 亚洲精品在线观看视频| 久久精品视频播放| 亚洲最新色图| 欧美成人综合一区| 狠狠色狠狠色综合日日五| 亚洲女优在线| 亚洲精品国产精品乱码不99| 久久久久久亚洲精品中文字幕| 国产精品国产三级国产普通话蜜臀 | 欧美大片在线看| 国产综合欧美在线看| 亚洲一区视频在线| 亚洲人体一区| 久久男女视频| 国产深夜精品福利| 亚洲一区二区三区四区中文 | 欧美一区二区三区四区在线| 欧美精品乱码久久久久久按摩| 国产日韩久久| 性欧美大战久久久久久久久| 亚洲毛片在线观看.| 欧美粗暴jizz性欧美20| 亚洲高清123| 老巨人导航500精品| 欧美一区二区视频免费观看| 国产麻豆综合| 午夜精品久久久久久久蜜桃app | 欧美激情久久久久久| 久久精品国产第一区二区三区最新章节 | 欧美一区二区三区免费观看| 99国产精品久久久久久久久久| 欧美黄网免费在线观看| 亚洲人成小说网站色在线| 免费观看成人www动漫视频| 欧美在线一二三区| 国产亚洲制服色| 久久久久国产一区二区三区| 校园激情久久| 国产视频不卡| 久久国产日韩欧美| 亚洲欧美日韩综合aⅴ视频| 国产精品亚洲一区二区三区在线| 亚洲免费视频在线观看| 亚洲午夜久久久久久尤物 | 欧美精品一区三区在线观看| 亚洲精品视频免费| 亚洲全黄一级网站| 欧美人与性动交cc0o| 一区二区激情| 99视频在线观看一区三区| 国产精品www色诱视频| 欧美一级黄色录像| 久久国产乱子精品免费女 | 亚洲视频在线观看三级| 一区二区三区国产精品| 国产精品资源| 久久亚洲精品中文字幕冲田杏梨| 久久久国产视频91| 亚洲激情偷拍| 亚洲看片免费| 国产精品亚洲综合一区在线观看| 久久精品国产77777蜜臀| 久久不射2019中文字幕| 亚洲电影在线播放| 亚洲精品国产无天堂网2021| 国产精品国色综合久久| 久久精品在线视频| 免费高清在线视频一区·| 一区二区三区产品免费精品久久75| 亚洲视频精选| 激情综合亚洲| 亚洲精品国产系列| 国产精品一区二区三区观看| 久久综合九色99| 欧美日本二区| 久久精品91久久久久久再现| 久久女同互慰一区二区三区| 一区二区激情小说| 校园春色综合网| 亚洲精品国产拍免费91在线| 亚洲无限乱码一二三四麻| 精品动漫3d一区二区三区免费| 亚洲人成亚洲人成在线观看图片| 国产精品久久久久秋霞鲁丝| 美女视频网站黄色亚洲| 欧美日韩另类一区| 久久青草福利网站| 欧美另类人妖| 久久亚洲影音av资源网| 欧美日韩亚洲一区二区三区| 久久亚洲春色中文字幕久久久| 欧美日韩黄色大片| 久久婷婷色综合| 欧美午夜一区| 欧美电影在线免费观看网站| 国产精品欧美日韩一区二区| 欧美激情一区二区久久久| 国产欧美精品日韩| 亚洲日韩中文字幕在线播放| 国内偷自视频区视频综合| 亚洲精品资源美女情侣酒店| 怡红院精品视频在线观看极品| 一区二区三区毛片| 亚洲精品永久免费| 久久精品国产999大香线蕉| 亚洲欧美日韩另类| 欧美精品一区二区精品网| 久久综合九色综合网站| 国产精品视频导航| 亚洲精品一区二区网址|