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

隨筆 - 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 英雄哪里出來 閱讀(1205) 評論(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>
            日韩视频在线你懂得| 国产亚洲欧美激情| 亚洲电影观看| 欧美综合国产| 久久精品一区二区| 香蕉久久国产| 欧美一区二区三区另类 | 亚洲图片在线观看| 亚洲区欧美区| 日韩午夜av在线| 亚洲欧美日韩区| 亚洲一区欧美一区| 欧美在线网站| 欧美a级大片| 国产精品亚洲产品| 国内外成人免费激情在线视频| 国产一区二区无遮挡| 亚洲国产精品黑人久久久| 精品成人乱色一区二区| 亚洲电影第1页| 亚洲图片你懂的| 久久久噜噜噜久久中文字幕色伊伊| 久久天天狠狠| 99热精品在线观看| 久久久一区二区三区| 国产精品久久毛片a| 亚洲人成艺术| 久久精品72免费观看| 91久久中文| 欧美激情亚洲国产| 亚洲专区免费| 欧美一区在线直播| 欧美视频精品一区| 亚洲日本在线观看| 久久影音先锋| 欧美一级视频免费在线观看| 欧美日韩国产成人高清视频| 国语精品中文字幕| 欧美影院视频| 亚洲色图自拍| 国产精品欧美一区二区三区奶水| 亚洲少妇在线| 一区二区电影免费在线观看| 免费在线一区二区| 亚洲高清色综合| 亚洲国产精品国自产拍av秋霞 | 日韩视频在线观看免费| 亚洲片区在线| 国产精品成人观看视频免费| 9久re热视频在线精品| 日韩视频一区二区三区在线播放免费观看 | 久久亚洲视频| 欧美巨乳波霸| 欧美亚洲一区二区在线| 亚洲图片欧美午夜| 久久在线观看视频| 亚洲激情自拍| 亚洲影视综合| 亚洲国产精品视频| 一级日韩一区在线观看| 亚洲精品中文在线| 国产一区二区电影在线观看 | 亚洲性夜色噜噜噜7777| 在线中文字幕不卡| 一区二区在线观看视频| 中文久久精品| 日韩一区二区电影网| 久久精品麻豆| 午夜精品免费视频| 蜜臀av性久久久久蜜臀aⅴ四虎 | 国产精品久久二区二区| 欧美成人三级在线| 精品动漫一区| 久久精品亚洲一区| 久久精品夜色噜噜亚洲a∨| 国产精品二区在线| 日韩一区二区精品视频| 亚洲一二三区在线观看| 欧美日韩免费在线观看| 女人香蕉久久**毛片精品| 国产毛片久久| 久久精品国产99精品国产亚洲性色 | 亚洲精品欧美日韩| 欧美成人小视频| 国产网站欧美日韩免费精品在线观看 | 久久久亚洲影院你懂的| 国产午夜一区二区三区| 香蕉av福利精品导航| 久久先锋资源| 亚洲三级影片| 国产伦理一区| 久久色中文字幕| 亚洲成色999久久网站| 亚洲精选一区| 国产精品丝袜白浆摸在线| 久久久久久国产精品一区| 欧美不卡一区| 性欧美精品高清| 狠狠综合久久av一区二区老牛| 久久九九精品99国产精品| 91久久久久| 久久成人18免费网站| 制服诱惑一区二区| 久久综合999| 亚洲自拍偷拍视频| 亚洲日本中文| 亚洲国产导航| 欧美国产丝袜视频| 久久亚洲春色中文字幕| 欧美在线亚洲在线| 国产精品乱码妇女bbbb| 亚洲精品久久久蜜桃 | 国产情侣久久| 欧美激情二区三区| 欧美ab在线视频| 亚洲一区欧美| 亚洲一区综合| 亚洲综合色激情五月| 亚洲精品国产视频| 亚洲国产视频a| 亚洲高清资源| 亚洲成人资源网| 亚洲精选一区| 欧美在线观看一二区| 香蕉成人伊视频在线观看 | 欧美中在线观看| 久久看片网站| 欧美日韩精品一区视频 | 久久精品麻豆| 老牛影视一区二区三区| 欧美二区不卡| 国产精品夜色7777狼人| 激情一区二区三区| 亚洲日本激情| 欧美一区二区三区久久精品| 久久国产综合精品| 亚洲第一页中文字幕| 亚洲一区自拍| 欧美jjzz| 国产精品免费网站| 在线观看欧美日本| 久久精品国产91精品亚洲| 欧美激情精品久久久久久大尺度| 欧美黑人在线观看| 午夜欧美精品| 欧美精品成人91久久久久久久| 国内精品久久久久影院优| 日韩视频在线观看免费| 久久亚洲精品一区二区| 亚洲视频电影图片偷拍一区| 欧美成年网站| 亚洲美女av在线播放| 欧美激情精品久久久六区热门 | 欧美.com| 精久久久久久| 欧美一级视频精品观看| 欧美日韩国产首页在线观看| 亚洲福利一区| 亚洲精品社区| 欧美日韩免费观看一区三区| 99精品久久久| 亚洲欧洲免费视频| 欧美精品电影在线| 亚洲小说区图片区| 亚洲欧美激情一区二区| 国产在线不卡视频| 亚洲国产精品视频| 欧美日韩mp4| 久久综合久久综合久久综合| 免费一级欧美在线大片| 9久re热视频在线精品| 一本一本久久| 尤物视频一区二区| 亚洲午夜在线视频| 亚洲日本欧美| 亚洲欧美在线一区| 亚洲国产一区在线观看| 宅男精品视频| 一区二区欧美日韩| 欧美一区二区| 性视频1819p久久| 欧美精品久久99久久在免费线| 亚洲免费在线观看视频| 久久婷婷丁香| 久久久久久有精品国产| 欧美性视频网站| 亚洲国产婷婷| 亚洲国产美女久久久久| 亚洲欧美在线播放| 亚洲天堂成人在线观看| 欧美激情综合色| 欧美福利一区二区三区| 红桃视频一区| 鲁鲁狠狠狠7777一区二区| 欧美一二三视频| 国产综合亚洲精品一区二| 久久av红桃一区二区小说| 久久视频一区| 亚洲高清影视| 亚洲国产精品久久久久秋霞影院|