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

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

PKU 2528 Mayor's posters

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

/*
題意:
    給定N(N <= 10000)塊木板,依次層疊,問最后能從上方俯視的木板的數量。


解法:
線段樹(染色問題)

思路:
    這題是pku 2777的簡化版,木板的數量最多10000種,每個結點都保存下來
似乎有點力不從心,但是因為插入是多次,而詢問只有一次,所以我們只要保證
插入是O(logn)的,而詢問可以O(n),這樣問題就變得簡單許多,線段樹結點保存
一個Cover域,初始化為0,表示是0號木板(輸入數據的木板編號從1開始),每
次插入時只更新到完全覆蓋的區間,如果當前結點的左右兒子的木板顏色不同,
那么它的Cover域就是-1,否則是木板的下標。詢問的時候如果遇到Cover域為-1
的結點則遞歸它的子結點,否則統計。
*/


#include 
<iostream>
#include 
<algorithm>
using namespace std;

#define maxn 100010

int tmp[maxn], tmpsize;
int bin[maxn], size;

struct Interval {
    
int l, r;
}
I[maxn];

struct Tree {
    
int nCover;
    
int son[2];

    
void clear() {
        son[
0= son[1= -1;
        nCover 
= 0;
    }

}
T[ maxn*4 ];
int root, tot = 0;

int GetId(int& root) {
    
if(root == -1{
        root 
= tot++;
        T[root].clear();
    }

    
return root;
}


void Discretization() {
    sort(tmp, tmp 
+ tmpsize);
    bin[ size 
= 1 ] = tmp[0];
    
int i;
    
for(i = 1; i < tmpsize; i++{
        
if(tmp[i] != tmp[i-1])
            bin[ 
++size ] = tmp[i];
    }

}


int Binary(int v) {
    
int l = 1;
    
int r = size;
    
while(l <= r) {
        
int m = (l + r) >> 1;
        
if(bin[m] == v)
            
return m;
        
if(v > bin[m]) {
            l 
= m + 1;
        }
else
            r 
= m - 1;
    }

}


int hash[ maxn ], Case;

void Insert(int& root, int nl, int nr, int l, int r, int val) {
    
if(nl > r || nr < l)
        
return ;

    GetId(root);
    
if(nl <= l && r <= nr) {
        T[root].nCover 
= val;
        
return ;
    }


    
if(T[root].nCover != -1{
        
int i;
        
for(i = 0; i < 2; i++{
            
int idx = GetId(T[root].son[i]);
            T[idx].nCover 
= T[root].nCover;
        }

        T[root].nCover 
= -1;
    }


    
int mid = (l + r) >> 1;
    Insert(T[root].son[
0], nl, nr, l, mid, val);
    Insert(T[root].son[
1], nl, nr, mid+1, r, val);
}


void Query(int root, int l, int r) {
    
if(root == -1)
        
return ;
    
if(T[root].nCover != -1{
        hash[ T[root].nCover ] 
= Case;
        
return ;
    }

    
int mid = (l + r) >> 1;
    Query(T[root].son[
0], l, mid);
    Query(T[root].son[
1], mid+1, r);
}


int main() {
    
int t, i;
    
int n;
    scanf(
"%d"&t);
    
while(t--{
        Case 
++;
        tmpsize 
= 0;
        scanf(
"%d"&n);
        
for(i = 0; i < n; i++{
            scanf(
"%d %d"&I[i].l, &I[i].r);
            tmp[ tmpsize 
++ ] = I[i].l;
            tmp[ tmpsize 
++ ] = I[i].r;
        }

        Discretization();
        root 
= -1;
        tot  
= 0;
        
for(i = 0; i < n; i++{
            I[i].l 
= Binary(I[i].l);
            I[i].r 
= Binary(I[i].r);
            
//printf("<%d %d>\n", I[i].l, I[i].r);
            Insert(root, I[i].l, I[i].r, 1, size, i+1);
        }

        
int nCount = 0;
        Query(root, 
1, size);
        
for(i = 1; i <= size; i++{
            
if(hash[i] == Case)
                nCount 
++;
        }

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

    
return 0;
}

posted on 2011-03-31 21:23 英雄哪里出來 閱讀(1211) 評論(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>
            亚洲综合国产精品| 亚洲自拍偷拍网址| 欧美国产精品| 99国产精品私拍| 欧美一区二区三区男人的天堂| 国产欧美三级| 久久综合影音| 夜夜嗨av一区二区三区网站四季av | 在线欧美日韩| 欧美日韩精品福利| 午夜精品久久久久久久99热浪潮| 久久夜色精品亚洲噜噜国产mv | 久久久噜噜噜久久久| 亚洲国产精品综合| 亚洲女性裸体视频| 136国产福利精品导航网址| 欧美日韩ab| 欧美伊久线香蕉线新在线| 亚洲国产精品一区制服丝袜| 亚洲综合好骚| 亚洲高清色综合| 国产精品jizz在线观看美国| 久久久久国产精品一区二区| 99riav国产精品| 蜜桃久久精品一区二区| 中文亚洲字幕| 黄色亚洲网站| 国产精品成人观看视频国产奇米| 久久精品免视看| 在线一区免费观看| 欧美寡妇偷汉性猛交| 香蕉尹人综合在线观看| 亚洲精品在线观看免费| 狠狠色狠色综合曰曰| 欧美性色综合| 欧美劲爆第一页| 久久久www成人免费无遮挡大片| 夜夜嗨av一区二区三区四季av | 欧美国产一区二区| 久久高清免费观看| 亚洲天堂免费在线观看视频| 亚洲国产精品一区二区尤物区| 久久久久女教师免费一区| 亚洲一区二区精品| 91久久久久久国产精品| 国产综合色产| 国产美女在线精品免费观看| 欧美日韩视频在线| 欧美成人影音| 欧美 日韩 国产一区二区在线视频| 欧美亚洲一区二区在线| 亚洲视屏一区| 一本大道av伊人久久综合| 亚洲激情在线视频| 欧美国产综合视频| 欧美二区乱c少妇| 快射av在线播放一区| 久久久97精品| 欧美在线视频一区二区三区| 午夜久久99| 午夜精品电影| 午夜亚洲性色视频| 亚洲欧美一区二区三区在线| 亚洲在线视频免费观看| 亚洲午夜电影网| 亚洲一区在线直播| 亚洲欧美日韩爽爽影院| 亚洲女性裸体视频| 性色av香蕉一区二区| 性视频1819p久久| 欧美一区二区私人影院日本| 欧美一级淫片播放口| 欧美在线地址| 久久亚洲捆绑美女| 蜜桃久久精品乱码一区二区| 免费一级欧美片在线观看| 欧美777四色影视在线| 欧美成人精品福利| 亚洲国产视频a| 日韩一区二区久久| 亚洲午夜精品久久| 欧美一区二区三区另类| 久久国产天堂福利天堂| 久热精品在线视频| 欧美精品激情在线| 国产精品久久久一区麻豆最新章节| 国产精品视频九色porn| 国产亚洲一二三区| 亚洲高清在线观看| 一区二区三区视频在线观看| 亚洲欧美日韩精品久久亚洲区| 久久超碰97中文字幕| 免费成人黄色av| 亚洲欧洲一区二区三区久久| 在线亚洲精品| 久久久精品动漫| 欧美精品一区二区三区久久久竹菊| 欧美日韩久久精品| 国产欧美精品在线| 亚洲国产精品精华液2区45| 一区二区欧美在线观看| 久久精品成人| 亚洲国产精品久久久久婷婷老年| 一本到高清视频免费精品| 性视频1819p久久| 蜜乳av另类精品一区二区| 欧美视频免费| 激情校园亚洲| 亚洲在线第一页| 欧美成人精品不卡视频在线观看 | 一级成人国产| 久久久美女艺术照精彩视频福利播放 | 99精品欧美一区二区蜜桃免费| 亚洲男人的天堂在线aⅴ视频| 麻豆国产精品777777在线| 国产精品成人va在线观看| 精品999网站| 亚洲综合成人在线| 男人天堂欧美日韩| 亚洲图片自拍偷拍| 欧美承认网站| 国语自产偷拍精品视频偷| 亚洲特级毛片| 欧美黑人一区二区三区| 亚洲一区免费在线观看| 欧美大尺度在线| 韩日视频一区| 午夜视频在线观看一区| 91久久精品网| 久久久99久久精品女同性| 国产精品蜜臀在线观看| 99精品国产在热久久下载| 美国三级日本三级久久99| 亚洲午夜视频| 欧美日韩亚洲另类| 亚洲精品专区| 欧美成人精品h版在线观看| 欧美一级视频精品观看| 欧美日韩一区在线观看视频| 亚洲精品国产无天堂网2021| 久久伊伊香蕉| 欧美一区二区三区四区在线观看地址| 欧美日韩精品欧美日韩精品| 亚洲激情av| 蜜臀久久99精品久久久画质超高清 | 欧美三级特黄| 9色porny自拍视频一区二区| 欧美成人亚洲| 久久人人九九| 一区免费视频| 美女国内精品自产拍在线播放| 午夜一区不卡| 国产欧美一区二区三区国产幕精品 | 在线精品亚洲一区二区| 久久野战av| 久久久免费精品视频| 狠狠色丁香久久综合频道| 久久精品亚洲精品| 午夜精品一区二区三区四区| 国产伦精品一区二区三区高清| 亚洲一区中文字幕在线观看| 亚洲视频香蕉人妖| 国产精品超碰97尤物18| 亚洲男人第一网站| 亚洲欧美国产日韩中文字幕| 国产精品尤物| 久久久久久久网| 久久一本综合频道| 亚洲精品一区二区在线| 亚洲欧洲日夜超级视频| 欧美日韩综合精品| 亚洲在线视频观看| 欧美亚洲在线观看| 亚洲电影免费在线观看| 欧美黄色大片网站| 欧美日韩国产综合久久| 亚洲伊人久久综合| 欧美一区1区三区3区公司| 一区精品久久| 亚洲看片网站| 国产精品一区免费在线观看| 久久噜噜亚洲综合| 久久综合导航| 国产精品99久久久久久宅男| 亚洲欧美国产77777| 黄网站免费久久| 亚洲国产色一区| 国产精品亚洲综合色区韩国| 久久这里有精品视频| 欧美精品亚洲精品| 欧美一区二区高清在线观看| 久久蜜臀精品av| 一区二区三区免费观看| 午夜亚洲福利| 亚洲精品一区在线观看| 亚洲一区欧美激情| 亚洲欧洲中文日韩久久av乱码| 一本久久a久久免费精品不卡| 国产一区久久| 亚洲精品在线电影|