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

ACM___________________________

______________白白の屋
posts - 182, comments - 102, trackbacks - 0, articles - 0
<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

常用鏈接

留言簿(24)

隨筆分類(332)

隨筆檔案(182)

FRIENDS

搜索

積分與排名

最新隨筆

最新評論

閱讀排行榜

評論排行榜

MiYu原創(chuàng), 轉(zhuǎn)帖請注明 : 轉(zhuǎn)載自 ______________白白の屋    

題目地址 :

http://poj.org/problem?id=2528

題目描述:

Mayor's posters
Time Limit: 1000MSMemory Limit: 65536K
Total Submissions: 15722Accepted: 4444

Description

The citizens of Bytetown, AB, could not stand that the candidates in the mayoral election campaign have been placing their electoral posters at all places at their whim. The city council has finally decided to build an electoral wall for placing the posters and introduce the following rules: 
  • Every candidate can place exactly one poster on the wall. 
  • All posters are of the same height equal to the height of the wall; the width of a poster can be any integer number of bytes (byte is the unit of length in Bytetown). 
  • The wall is divided into segments and the width of each segment is one byte. 
  • Each poster must completely cover a contiguous number of wall segments.

They have built a wall 10000000 bytes long (such that there is enough place for all candidates). When the electoral campaign was restarted, the candidates were placing their posters on the wall and their posters differed widely in width. Moreover, the candidates started placing their posters on wall segments already occupied by other posters. Everyone in Bytetown was curious whose posters will be visible (entirely or in part) on the last day before elections. 
Your task is to find the number of visible posters when all the posters are placed given the information about posters' size, their place and order of placement on the electoral wall. 

Input

The first line of input contains a number c giving the number of cases that follow. The first line of data for a single case contains number 1 <= n <= 10000. The subsequent n lines describe the posters in the order in which they were placed. The i-th line among the n lines contains two integer numbers li and ri which are the number of the wall segment occupied by the left end and the right end of the i-th poster, respectively. We know that for each 1 <= i <= n, 1 <= li <= ri <= 10000000. After the i-th poster is placed, it entirely covers all wall segments numbered li, li+1 ,... , ri.

Output

For each input data set print the number of visible posters after all the posters are placed. 

The picture below illustrates the case of the sample input. 

Sample Input

1
5
1 4
2 6
8 10
3 4
7 10

Sample Output

4

 題目分析 :

代碼
/*
   線段樹 +  離散化
    
   好像記得暑假做 樹狀數(shù)組的時候 做過一個離散化的題目, 當(dāng)時是用2分查詢
   離散節(jié)點(diǎn)標(biāo)記的, 速度還是可以的, 不過那時對離散化也沒有什么概念, 大
   概是沒怎么接觸, 今天做了這道題目的時候,  也算是明白了 離散化 的基本
   意思,因?yàn)?nbsp;題目的 數(shù)據(jù)范圍很大 , 1- 10000000,直接線段樹的話, 先不說
   內(nèi)存會不會爆, 這么大的范圍估計(jì)也是 TLE了. 
   仔細(xì)讀題, 可以看到  1<= N <= 10000, 也就是說 最多只有 10000個點(diǎn), 如果
   每個點(diǎn)都不同, 那么最多也只有 20000 個數(shù)據(jù), 那么離散后的 范圍就相當(dāng)小;
   
   離散化 的大概思路 :   比如說給你一組 數(shù)據(jù) 1 4 1000 100000,  如果直接
                         開線段, 顯然是浪費(fèi), 那么我們只要 進(jìn)行 映射 :
                                1    1  
                                4    2
                             1000    3
                           100000    4
                         接下來 我們只要對 1 2 3 4 建立線段樹就行了 只需要
                         [1,4]的區(qū)間     
*/

/*
Mail to   : miyubai@gamil.com
Link      : 
http://www.cnblogs.com/MiYu  || http://www.shnenglu.com/MiYu
Author By : MiYu
Test      : 1
Complier  : g++ mingw32-3.4.2
Program   : 2528
Doc Name  : Mayor's posters
*/
//#pragma warning( disable:4789 )
#include <iostream>
#include 
<fstream>
#include 
<sstream>
#include 
<algorithm>
#include 
<string>
#include 
<set>
#include 
<map>
#include 
<utility>
#include 
<queue>
#include 
<stack>
#include 
<list>
#include 
<vector>
#include 
<cstdio>
#include 
<cstdlib>
#include 
<cstring>
#include 
<cmath>
#include 
<ctime>
using namespace std;
int T, N, x, y;
map 
< intint > mp;
set <int> st;
map
<int,int>::iterator beg, end;
struct segtree {
       
int left, right,cov;
       
int mid () { return (left+right)>>1; }
}seg[
80010];
struct P {  //節(jié)點(diǎn)數(shù)據(jù) 
       int left, right;
}pp[
10010];
void creat ( int x, int y, int rt = 1 ) {
     seg[rt].left 
= x;
     seg[rt].right 
= y;
     seg[rt].cov 
= 0;
     
if ( x == y ) return ;
     
int mid = seg[rt].mid();
     creat ( x, mid, rt 
<< 1 );
     creat ( mid 
+ 1, y, rt << 1 | 1 );     
}
void insert ( int x, int y, int flag, int rt = 1 ) {
     
//如果線段被覆蓋, 直接標(biāo)記, 返回 
    if ( seg[rt].left == x && seg[rt].right == y ) {
        seg[rt].cov 
= flag;
        
return;   
    }    
    
int LL = rt << 1, RR = rt << 1 | 1, mid = seg[rt].mid();
    
if ( seg[rt].cov != -1 ) {  
       
//如果線段是被覆蓋的 , 標(biāo)記下傳, 同時自身標(biāo)記-1,表示有多個標(biāo)記 
        seg[LL].cov = seg[RR].cov = seg[rt].cov;
        seg[rt].cov 
= -1;   
    }
    
//遞歸 插入 
    if ( y <= mid ) insert ( x, y, flag, LL );
    
else if ( x > mid ) insert ( x, y, flag, RR );
    
else {
          insert ( x, mid, flag, LL );
          insert ( mid 
+ 1, y, flag, RR );     
    }
}
void query ( int x, int y, int rt = 1 ) {
    
// 線段被覆蓋 , 將覆蓋標(biāo)記 放入 set 
    if ( seg[rt].cov != -1 && seg[rt].left == x && seg[rt].right == y ) {
        st.insert ( seg[rt].cov );
        
return ;   
    }
else {//遞歸查詢 
          int LL = rt << 1, RR = rt << 1 | 1, mid = seg[rt].mid();
          
if ( y <= mid ) query ( x, y, rt << 1 ); 
          
else if ( x > mid ) query ( x, y, rt << 1 | 1 );
          
else {
                query ( x, mid, LL );
                query ( mid 
+ 1, y, RR );     
          }
    }
}
void print () {
     
for ( set<int>::iterator it = st.begin(); it != st.end(); ++ it )
           cout 
<< *it << endl;     
}
int main ()
{
    scanf ( 
"%d"&T );
    creat ( 
120010 );
    
while ( T -- ) {
           mp.clear();
           st.clear (); 
           scanf ( 
"%d"&N );
           
for ( int i = 1; i <= N; ++ i ) {
                scanf ( 
"%d%d"&pp[i].left, &pp[i].right );
                 
//map 去重 
                mp[pp[i].left] = 88; mp[pp[i].right] = 88;    
           }      
           beg 
= mp.begin(), end = mp.end();
           
//因?yàn)閙ap 已經(jīng)自動排序了,所以直接從 1 --> N 開始標(biāo)記, 離散化 
           for ( int i = 1;beg != end; ++ beg, ++ i ) {         
                beg
->second = i;  
           }
           
//因?yàn)榫€段樹已經(jīng)建立好了, 所以沒必要每次都重建一次, 只要插入一條
           
//覆蓋所有區(qū)間的 底板 就行了 
           insert ( 1, N * 20 );
           
for ( int i = 1; i <= N; ++ i ) {
                
//用離散后的標(biāo)記 插入 線段 
                insert ( mp[pp[i].left], mp[pp[i].right], i );   
           }
           query ( 
1, N * 2 );
           
//print();
           int cnt = st.size();
           
if ( *st.begin() == 0 ) -- cnt; 
           printf ( 
"%d\n", cnt );
    }

    
return 0;
}

 

Feedback

# re: PKU 2528 POJ 2528 Mayor's posters ( 線段樹+離散化 ) ACM 2528 IN PKU  回復(fù)  更多評論   

2011-10-19 22:34 by wjjay
3
1 10
1 5
7 10
請問這組數(shù)據(jù)在你程序里跑出來的結(jié)果跟你手算的一樣么?
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 国产在线成人| 国产在线不卡视频| 伊人精品成人久久综合软件| 黄色在线一区| 国产精品网站一区| 欧美精品一区二区三区很污很色的 | 久久综合色婷婷| 在线一区二区视频| 欧美jizz19性欧美| 亚洲高清久久| 亚洲第一精品夜夜躁人人躁| 91久久精品美女| 欧美一二区视频| 欧美成年视频| 亚洲狠狠丁香婷婷综合久久久| 亚洲国产精品一区二区三区| 麻豆freexxxx性91精品| 午夜精品久久久久久99热| 欧美一区二区精品在线| 亚洲国产经典视频| 亚洲天堂久久| 亚洲香蕉网站| 亚洲一区日韩| 久久国产精品99国产精| 欧美va亚洲va香蕉在线| 亚洲国内精品| 亚洲五月婷婷| 99精品视频免费全部在线| 欧美黑人国产人伦爽爽爽| 亚洲欧洲日韩女同| 中文欧美日韩| 久久久久久久久久久成人| 欧美成年人视频网站欧美| 国产精品久久久久久久久久久久| 免费视频亚洲| 国产精品久久福利| 国内免费精品永久在线视频| 亚洲欧洲精品成人久久奇米网| 99视频在线观看一区三区| 亚洲女人天堂成人av在线| 美女在线一区二区| 一本色道婷婷久久欧美| 亚洲一区二区av电影| 亚洲欧美日韩综合| 欧美激情1区2区| 国产中文一区二区| 亚洲男女自偷自拍图片另类| 欧美成人一区在线| 性色av一区二区三区| 欧美日韩免费一区二区三区| 樱桃成人精品视频在线播放| 亚洲欧美激情在线视频| 久久国产精品久久国产精品| 亚洲另类自拍| 免费成人高清在线视频| 国产日韩av高清| 国产精品99久久久久久白浆小说| 欧美a级片网| 欧美在线免费观看| 国产精品视频yy9099| 99精品热视频| 亚洲激情自拍| 欧美激情女人20p| 在线看不卡av| 久久这里只有精品视频首页| av成人国产| 亚洲激情网站免费观看| 久久久亚洲精品一区二区三区| 一本高清dvd不卡在线观看| 亚洲国产精品一区二区三区| 久久另类ts人妖一区二区| 国产日韩av高清| 欧美一级视频一区二区| av成人福利| 欧美午夜精品理论片a级大开眼界 欧美午夜精品理论片a级按摩 | 久久蜜桃精品| 亚洲欧美视频| 国产精品网站视频| 性欧美精品高清| 亚洲夜间福利| 国产欧美一区二区白浆黑人| 亚洲精品影院在线观看| 亚洲国产美女精品久久久久∴| 免费观看成人www动漫视频| 在线看片欧美| 欧美成人免费网站| 欧美激情视频给我| 亚洲欧美日韩爽爽影院| 性感少妇一区| 国产欧美精品一区二区色综合 | 亚洲视频在线看| 99精品欧美一区二区三区综合在线| 欧美日本久久| 性视频1819p久久| 久久精品亚洲热| 91久久夜色精品国产网站| 亚洲三级影院| 欧美日韩在线亚洲一区蜜芽 | 一区二区视频免费完整版观看| 欧美mv日韩mv国产网站| 欧美国产精品一区| 亚洲女女做受ⅹxx高潮| 久久理论片午夜琪琪电影网| 亚洲精品网站在线播放gif| 久久久91精品国产一区二区精品| 国产精品theporn| 午夜精品视频在线观看| 99视频精品免费观看| 欧美日韩国产一中文字不卡| 一区二区免费看| 午夜伦理片一区| 亚洲精品国产精品乱码不99按摩| 中国成人在线视频| 在线观看国产精品网站| 麻豆国产精品一区二区三区| 久久精品亚洲精品| 理论片一区二区在线| 国产精品99久久久久久久久 | 亚洲欧洲视频在线| 久久一区亚洲| 欧美不卡在线视频| 激情欧美日韩一区| 欧美一区二区在线| 久久精品首页| 国产婷婷色一区二区三区在线| 亚洲一区二区视频在线| 亚洲欧美国产高清| 国产精品日韩一区二区| 亚洲视频一二三| 亚洲欧美日本国产有色| 国产精品日韩在线观看| 亚洲在线视频网站| 欧美在线视频在线播放完整版免费观看| 国产精品免费电影| 亚洲免费一级电影| 久久久久久尹人网香蕉| 国产一区三区三区| 久久亚洲欧美| 亚洲电影在线免费观看| 亚洲精品一区二区三区婷婷月| 免费在线观看精品| 日韩亚洲欧美综合| 亚洲自啪免费| 狠狠色综合日日| 亚洲激情成人| 亚洲一区二区三区欧美| 国产美女精品视频| 久久精品国产99国产精品澳门| 老司机免费视频一区二区三区| 亚洲人成艺术| 国产精品久久777777毛茸茸| 欧美一级一区| 亚洲激情第一页| 午夜精品999| 亚洲国产精品一区二区尤物区| 欧美日韩不卡合集视频| 香蕉乱码成人久久天堂爱免费| 欧美超级免费视 在线| 亚洲一区二区三区高清不卡| 国产一区视频在线观看免费| 免费美女久久99| 99综合视频| 免费成人av资源网| 中文无字幕一区二区三区| 狠狠色狠狠色综合日日tαg | 欧美成人乱码一区二区三区| 一区二区三区欧美视频| 国产亚洲亚洲| 欧美日韩不卡一区| 久久一区二区三区超碰国产精品 | 久久国产手机看片| 亚洲九九精品| 欧美福利影院| 久久狠狠婷婷| 一区二区三区欧美视频| 国产综合视频在线观看| 欧美午夜精品理论片a级大开眼界| 久久久美女艺术照精彩视频福利播放| 亚洲精品视频啊美女在线直播| 久久大综合网| 亚洲无线视频| 久久久综合免费视频|