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

C小加

厚德 博學 求真 至善 The bright moon and breeze
posts - 145, comments - 195, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

poj 2528 NYOJ 9 Mayor's posters 解題報告(2)

Posted on 2011-11-17 12:21 C小加 閱讀(6024) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告
NYOJ地址:http://acm.nyist.net/JudgeOnline/problem.php?pid=9
題意:往區間[1, 10000000]的墻上貼海報,海報數量的區間是[1,10000],后貼的會覆蓋之前的,問最后能看到的海報數量。
思路:離散化+并查集。張云聰學長的方法,寫著很給力啊,效率要比線段樹高。離散化后從最后一張海報開始,把每一段的根節點都置為海報的起始節點,這樣下一張海報訪問任何一節點的時候都會直接訪問到根節點,節省了訪問次數。

#include 
<iostream>
#include 
<cstdio>
#include 
<algorithm>
#include 
<cstring>
using namespace std;
const int MAXN=30003;
inline 
int L(int r){return r<<1;}
inline 
int R(int r){return ((r<<1)+1);}
inline 
int MID(int l,int r) {return (l+r)>>1;}

typedef 
struct NODE
{
    
int value,zy;
    
bool operator < (const NODE& r) const
    {
        
return value<r.value;
    }
}NODE;
NODE node[MAXN];
int post[MAXN][2];
int f[MAXN];
bool cnt[MAXN];
int sum;
int find(int x)
{
    
return f[x]==-1?x:f[x]=find(f[x]);
}

int main()
{
    
//freopen("input","r",stdin);
    int t;
    scanf(
"%d",&t);
    
while(t--)
    {
        
int n;
        scanf(
"%d",&n);
        
for(int i=0;i<n;i++)
        {
            scanf(
"%d%d",&post[i][0],&post[i][1]);//當前post為左右界坐標真值
            node[L(i)].zy=-i-1;//左值為負
            node[R(i)].zy=i+1;//右值為正
            node[L(i)].value=post[i][0];//把左右界坐標真值儲存在結構體數組中
            node[R(i)].value=post[i][1];
        }
        sort(node,node
+n*2);//對所有坐標進行排序
        int count=1,temp=node[0].value;//count為離散化后坐標值。
        for(int i=0;i<2*n;i++)
        {
            
if(node[i].value!=temp)//如果坐標不同,則坐標加1
            {
                count
++;
                temp
=node[i].value;
                
if(i!=0)         //空隙處理,寫的不是很好
                if(node[i-1].zy>0)
                
if((node[i-1].value+1)!=node[i].value)
                count
++;
            }

            
if(node[i].zy<0) post[-node[i].zy-1][0]=count;//新post為離散化過后,左右界值
            else post[node[i].zy-1][1]=count;
        }

        memset(f,
-1,sizeof(f));
        memset(cnt,
0,sizeof(cnt));
        sum
=0;
        
bool flag=0;
        
int l,r;
        
for(int i=n-1;i>=0;i--//從最后一張海報開始
        {
            l
=find(post[i][0]);//如果起點已經被覆蓋,就找到已覆蓋的最左端的節點。
            for(int j=post[i][1];j>=post[i][0];j=r-1)
            {
                r
=find(j);// 如果節點已被覆蓋,找到已覆蓋最左端的節點
                if(!cnt[r]) //如果此節點沒有被覆蓋
                {
                    cnt[r]
=1;
                    flag
=1;
                }
                
if(l!=r) f[r]=l; //每次讓右端的節點都指向最左端的節點,下次訪問的時候會直接跳到最左端的節點
            }
            
if(flag)sum++;
            flag
=0;
        }
        printf(
"%d\n",sum);


    }
    
return 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| 久色婷婷小香蕉久久| 亚洲人成人77777线观看| 久久久久久久成人| 狠狠色狠狠色综合| 欧美福利电影在线观看| 欧美成人精品福利| 亚洲少妇自拍| 亚洲欧美在线一区二区| 国产人成精品一区二区三| 欧美在线观看日本一区| 久久精品三级| 日韩亚洲国产精品| 亚洲亚洲精品在线观看| 国产综合欧美| 亚洲人成网站色ww在线| 欧美日韩久久精品| 久久精品视频在线看| 老司机午夜精品视频| 一区二区av| 小辣椒精品导航| 亚洲精品在线免费观看视频| 亚洲精选视频免费看| 国产免费成人| 亚洲黑丝在线| 国产午夜亚洲精品羞羞网站| 欧美激情片在线观看| 欧美日韩亚洲另类| 猫咪成人在线观看| 欧美日韩国产精品一区二区亚洲| 欧美一区二区免费观在线| 久久偷窥视频| 欧美一区二区三区四区视频| 欧美国产极速在线| 久久精品免费观看| 欧美日韩免费精品| 欧美+日本+国产+在线a∨观看| 欧美日韩成人一区二区三区| 久久精品盗摄| 欧美色中文字幕| 亚洲高清自拍| 韩日精品视频一区| 亚洲免费影视第一页| 亚洲乱码视频| 久久久亚洲国产美女国产盗摄| 亚洲在线一区二区| 欧美日本在线看| 欧美成人tv| 国产亚洲欧美日韩日本| 亚洲精品一区二区三区四区高清| 在线播放日韩专区| 欧美在线亚洲在线| 欧美亚洲免费高清在线观看| 欧美美女视频| 最新日韩在线| 日韩视频在线播放| 免费视频一区二区三区在线观看| 久久久久亚洲综合| 国产视频久久网| 亚洲女同在线| 欧美一级一区| 国产精品一二三四区| 亚洲色无码播放| 亚洲一区二区在线看| 欧美日韩亚洲视频一区| 日韩视频不卡| 亚洲一区二区三区在线看 | 校园春色综合网| 欧美日韩无遮挡| 日韩一二三在线视频播| 日韩一二三区视频| 欧美日韩三级视频| av成人免费观看| 亚洲欧美激情精品一区二区| 欧美日韩一区二区三区四区五区| 亚洲精品网址在线观看| 亚洲一区二区三区午夜| 国产精品久久一区二区三区| 亚洲午夜成aⅴ人片| 欧美一区二区三区久久精品| 国产视频久久网| 久久香蕉国产线看观看av| 免费日韩av| 一区二区三区国产精华| 国产精品久久久久91| 欧美亚洲一级片| 亚洲第一精品夜夜躁人人爽| 日韩亚洲国产精品| 国产精品视频网| 欧美在线免费观看视频| 亚洲大胆在线| 亚洲一区在线看| 好看的av在线不卡观看| 欧美国产日本高清在线| 亚洲一区二区三区中文字幕| 久久久久久**毛片大全| 亚洲九九精品| 国产精品久久久| 久久香蕉国产线看观看av| 亚洲精品欧美| 久久久精品国产免大香伊| 亚洲大片av| 国产精品你懂的在线| 久久精品免费播放| 亚洲精品久久久蜜桃| 久久国产精品久久w女人spa| 伊人精品在线| 国产精品欧美日韩一区二区| 久热精品在线视频| 亚洲一区www| 亚洲国产高清aⅴ视频| 午夜精品偷拍| 亚洲区一区二区三区| 国产亚洲一区二区三区在线观看 | 亚洲在线第一页| 欧美高清一区二区| 欧美一区在线直播| 一区二区三区毛片| 亚洲国产成人av| 国产精品专区一| 欧美日韩亚洲一区二区三区在线观看 | 日韩午夜在线播放| 美女主播一区| 久久国产精品99国产| 亚洲天堂偷拍| 亚洲巨乳在线| 在线精品福利| 加勒比av一区二区| 国产精品综合不卡av| 欧美日韩大片一区二区三区| 久久综合给合| 久久婷婷蜜乳一本欲蜜臀| 午夜久久久久久久久久一区二区| 洋洋av久久久久久久一区| 亚洲欧洲一区二区在线播放| 麻豆国产精品一区二区三区| 欧美一区二区三区日韩视频| 一区二区三区回区在观看免费视频| 亚洲高清色综合| 曰本成人黄色| 影音先锋欧美精品| 伊人狠狠色j香婷婷综合| 国产一区视频在线看| 国产视频精品xxxx| 国产婷婷97碰碰久久人人蜜臀| 国产精品日韩专区| 国产精品推荐精品| 国产麻豆精品视频| 国产女人水真多18毛片18精品视频| 国产精品萝li| 国产精品一区二区三区久久| 国产精品乱码| 国产欧美日韩免费| 韩国av一区二区三区| 在线播放日韩专区| 亚洲国产一区在线观看| 亚洲精品乱码久久久久久蜜桃麻豆 | 久久这里只精品最新地址| 麻豆精品在线视频| 欧美激情欧美激情在线五月| 欧美日韩第一页| 国产精品久久久久久五月尺| 国产精品亚洲а∨天堂免在线| 国产精品综合色区在线观看| 国产一区二区在线观看免费| 韩国精品久久久999| 亚洲三级电影全部在线观看高清| 亚洲精品日本| 午夜精品久久久久久久99樱桃 | 亚洲第一精品影视| 亚洲人成在线播放| 在线视频亚洲欧美| 欧美亚洲一级| 欧美电影专区| 国产精品视频九色porn| 狠狠入ady亚洲精品| 亚洲毛片av| 久久国产精品电影| 亚洲福利在线看| 中文精品在线| 久久亚洲精选| 国产精品久久久久久久app| 激情校园亚洲| 亚洲影视在线| 欧美v国产在线一区二区三区| 亚洲国产精品一区二区www在线| aa日韩免费精品视频一| 欧美在线观看一区二区三区| 欧美成人精品影院| 国产日本精品| 一本色道久久综合一区| 久久综合国产精品| 99视频精品全部免费在线| 欧美在线观看视频一区二区| 欧美猛交免费看| 亚洲第一黄网| 久久久水蜜桃av免费网站| 亚洲狼人精品一区二区三区| 久久国产精品网站| 国产精品卡一卡二卡三|