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

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

Pku 2777 Count Colors(線段樹)

/*
還是一個染色的覆蓋問題,修改一個區段的顏色,查詢一個區段有多少不同的顏色。
一開始用最原始的做法,修改,查詢,TLE了,然后去上體育課,突然就想到一個優化,
由于顏色只有30種,所以可以把各種顏色的狀態壓縮到一個整數中,這樣統計時就不用hash了
快了不少,哈哈!于是該線段樹共有兩個域,一個cover域,表明該區間下的顏色是單一的還是混合的,
還有一個計數域tree,該值表明該區間顏色的狀態。
*/

#include 
<iostream>

using namespace std;

int tree[1000010];
int cover[1000010];
int L, T, O;

int Build(int p, int l, int r) {

    
if(l == r) {
        tree[p] 
= 1;
        
return 1;
    }

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


int Update(int p, int a, int b, int l, int r, int color) {

    
if(cover[p] == color)
        
return tree[p];

    
if(a == l && r == b) {
        cover[p] 
= color; 
        
return ( 1<<(color-1) );
    }


    
if(cover[p] >= 1{
        cover[ 
2*p ] = cover[p];
        cover[ 
2*p+1 ] = cover[p];
        tree[
2*p] = tree[p];
        tree[
2*p+1= tree[p];
        cover[p] 
= -1;
    }


    
int mid = (l + r) / 2;
    
if(b <= mid) {
        tree[
2*p] = Update(2*p, a, b, l, mid, color);
    }
else if(mid + 1 <= a) {
        tree[
2*p+1= Update(2*p+1, a, b, mid+1, r, color);
    }
else {
        tree[
2*p] = Update(2*p, a, mid, l, mid, color);
        tree[
2*p+1= Update(2*p+1, mid+1, b, mid+1, r, color);
    }

    
return tree[2*p] | tree[2*p+1];
}


int Query(int p, int a, int b, int l, int r) {

    
if(cover[p] >= 1{
        
return tree[p];
    }

    
int mid = (l + r) / 2;
    
if(b <= mid) {
        
return Query(2*p, a, b, l, mid);
    }
else if(mid + 1 <= a){
        
return Query(2*p+1, a, b, mid+1, r);
    }
else {
        
int lef = Query(2*p, a, mid, l, mid);
        
int rig = Query(2*p+1, mid+1, b, mid+1, r);
        
return lef | rig;
    }

}


int main() {
    
char str[10];
    
int x, y, z;
    
int coun, i;
    
while(scanf("%d %d %d"&L, &T, &O) != EOF) {
        tree[
1= Build(11, L);
        
for(i = 1; i <= 1000000; i++)
            cover[i] 
= 1;
        
while(O --{
            scanf(
"%s", str);
            
if(str[0== 'C'{
                scanf(
"%d %d %d"&x, &y, &z);
                
if(x > y) {
                    
int temp = x;
                    x 
= y;
                    y 
= temp;
                }

                tree[
1= Update(1, x, y, 1, L, z);
            }
else {
                scanf(
"%d %d"&x, &y);    
                
if(x > y) {
                    
int temp = x;
                    x 
= y;
                    y 
= temp;
                }

                coun 
= 0;
                
int zty = Query(1, x, y, 1, L);
                
while(zty) {
                    
if(zty & 1)
                        coun 
++;
                    zty 
>>= 1;
                }

                printf(
"%d\n", coun);
            }

        }

    }

}

posted on 2009-04-07 21:10 英雄哪里出來 閱讀(402) 評論(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>
            先锋影音国产一区| 久久一区二区三区av| 亚洲欧美日韩成人| 午夜宅男欧美| 久久深夜福利免费观看| 黄色小说综合网站| 久久久www免费人成黑人精品| 午夜一区二区三区在线观看| 国语自产偷拍精品视频偷 | 久久人人爽人人爽| 欧美国产1区2区| 国产精品视频免费观看| 亚洲国产日韩欧美| 女女同性女同一区二区三区91| 娇妻被交换粗又大又硬视频欧美| 欧美成人综合一区| 亚洲精品一区二| 男人的天堂成人在线| 黄色在线一区| 欧美精品国产精品日韩精品| 亚洲成人中文| 久久人人爽人人| 日韩一级黄色大片| 欧美日韩另类国产亚洲欧美一级| 99国产精品久久久久久久| 久久香蕉精品| 亚洲欧美国产一区二区三区| 韩国免费一区| 国产在线视频欧美| 久久久久久久久久久久久女国产乱 | 欧美日韩激情小视频| 久久影视精品| 亚洲精品在线观看免费| 18成人免费观看视频| 欧美日韩一区成人| 欧美在线网站| 亚洲免费av观看| 午夜视频一区在线观看| 国产伦精品一区二区三区免费| 久久亚洲国产精品日日av夜夜| 翔田千里一区二区| 亚洲宅男天堂在线观看无病毒| 欧美好骚综合网| 亚洲——在线| 免播放器亚洲一区| 久久爱www久久做| 欧美一区二区三区日韩| 国产精品色在线| 亚洲电影网站| 亚洲精品国产精品国自产观看| 亚洲美女色禁图| 亚洲精品一区在线观看| 精品动漫3d一区二区三区免费| 一区二区三区在线观看国产| 国产精品美女视频网站| 国产精品专区h在线观看| 国产精品成人免费| 欧美日韩一区二区三区视频| 国产精品久久午夜| 国产午夜精品理论片a级大结局| 国产伦理一区| 亚洲六月丁香色婷婷综合久久| 99一区二区| 久久黄色级2电影| 一本色道久久综合亚洲精品高清| 欧美韩日一区| 香蕉久久国产| 久久激情久久| 这里只有精品电影| 亚洲欧美中文另类| 午夜精品福利在线| 亚洲国产合集| 在线观看日韩欧美| 伊人久久大香线| 国产一区二区精品在线观看| 国产精品狠色婷| 国产精品日本一区二区| 欧美精品一区在线发布| 国产区日韩欧美| 国产欧美日韩麻豆91| 国产日韩精品一区二区三区 | 亚洲精品久久久蜜桃| 精品成人国产在线观看男人呻吟| 在线日韩一区二区| 欧美成人xxx| 亚洲欧美在线播放| 国产精品一区在线播放| 亚洲第一色中文字幕| 亚洲综合精品一区二区| 老司机aⅴ在线精品导航| 亚洲网站在线| 亚洲欧美制服另类日韩| 亚洲影音先锋| 亚洲国产欧美日韩| 夜夜嗨av一区二区三区网站四季av| 欧美jizz19性欧美| 欧美一二三视频| 亚洲国产二区| 99精品热视频| 国产日韩欧美黄色| 免费国产一区二区| 久久午夜色播影院免费高清| 亚洲人成77777在线观看网| 欧美激情按摩在线| 国产精品二区二区三区| 亚洲直播在线一区| 99精品热6080yy久久| 久久福利精品| 国产精品稀缺呦系列在线| 伊人天天综合| 亚洲综合首页| 亚洲在线一区二区三区| 久久成人国产精品| 午夜精彩视频在线观看不卡 | 亚洲一区二区三区涩| 亚洲日韩欧美一区二区在线| 久久久亚洲欧洲日产国码αv| 毛片基地黄久久久久久天堂| 亚洲观看高清完整版在线观看| 欧美成人小视频| 狠狠爱综合网| 免费成人你懂的| 亚洲国产激情| 国产欧美另类| 欧美在线不卡| 久久精品国产2020观看福利| 国产一区二区无遮挡| 欧美福利视频| 亚洲永久在线| 亚洲欧美国产高清| 香蕉乱码成人久久天堂爱免费 | 欧美成人一品| 一本一本久久| 韩国精品在线观看| 亚洲精品日产精品乱码不卡| 午夜久久久久久| 老司机午夜免费精品视频| 亚洲国产精品久久久久秋霞蜜臀| 欧美日韩视频免费播放| 午夜精品久久久久影视| 亚洲美女淫视频| 亚洲欧洲日本在线| 久热成人在线视频| 91久久精品国产91性色tv| 日韩一二三在线视频播| 久久在线视频在线| 一区二区三区四区五区精品视频 | 欧美一激情一区二区三区| 国产视频丨精品|在线观看| 日韩视频在线免费| 美女视频网站黄色亚洲| 亚洲看片免费| 狠狠综合久久| 国产区精品在线观看| 在线精品国精品国产尤物884a| 久热精品在线视频| 欧美日韩亚洲综合在线| 欧美三级网址| 亚洲欧美日韩在线高清直播| 亚洲午夜羞羞片| 免费成人av| 国产精品有限公司| 一区二区三区视频在线| 久久亚洲国产精品一区二区 | 欧美专区中文字幕| 欧美一级久久久| 最新国产成人在线观看| 免费观看成人| 在线亚洲观看| 欧美在线播放一区| 国产伦精品一区二区三区四区免费| 精品成人一区二区三区| 最新日韩欧美| 999亚洲国产精| 免费观看国产成人| 亚洲麻豆一区| 亚洲国产精品激情在线观看| 亚洲一区中文| 麻豆av一区二区三区久久| 国产精品亚洲产品| 一本到12不卡视频在线dvd | 亚洲精品少妇网址| 亚洲一区日韩| 久久午夜羞羞影院免费观看| 一本色道久久综合亚洲精品不卡 | 宅男噜噜噜66国产日韩在线观看| 日韩亚洲欧美精品| 久久久久免费观看| 亚洲免费人成在线视频观看| 久久精品中文| 久久av二区| 国产精品久久久亚洲一区| 亚洲综合视频在线| 国产精品国产三级国产专区53| 欧美激情视频免费观看| 影院欧美亚洲| 麻豆国产精品777777在线| 久久久久在线观看| 国产亚洲视频在线观看| 99亚洲一区二区|