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

POJ 3277 City Horizon 線段樹+離散化

Description

Farmer John has taken his cows on a trip to the city! As the sun sets, the cows gaze at the city horizon and observe the beautiful silhouettes formed by the rectangular buildings.

The entire horizon is represented by a number line with N (1 ≤ N ≤ 40,000) buildings. Building i's silhouette has a base that spans locations Ai through Bi along the horizon (1 ≤ Ai < Bi ≤ 1,000,000,000) and has height Hi (1 ≤ Hi ≤ 1,000,000,000). Determine the area, in square units, of the aggregate silhouette formed by all N buildings.

Input

Line 1: A single integer: N
Lines 2..N+1: Input line i+1 describes building i with three space-separated integers: Ai, Bi, and Hi

Output

Line 1: The total area, in square units, of the silhouettes formed by all N buildings

Sample Input

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

Sample Output

16

Hint

The first building overlaps with the fourth building for an area of 1 square unit, so the total area is just 3*1 + 1*4 + 2*2 + 2*3 - 1 = 16.

Source

    題目的意思是說:平面上有[1,40000]個建筑,每個建筑有一個區間[Ai,Bi]表示它的跨度,Hi表示其高度。要求這n個建筑的平面覆蓋面積。
由于Ai,Bi∈[1,1000000000],直接將線段[Ai,Bi]插入線段樹空間消耗太大,可以將這n條線段的2n個端點離散化到一個數組X[0...2n-1],然后再將其插入線段樹,最后求出面積。
#include <iostream>
using namespace std;

const int MAXN = 40010;
struct segment{
    
int left,right,h;
}
tree[MAXN*3];
int pos[MAXN][3],x[MAXN*2],len;

int cmp1(const void *a,const void *b){
    
return *(int *)a-*(int *)b;
}

int cmp2(const void *a,const void *b){
    
return *((int *)a+2)-*((int *)b+2);
}

int query(int h){
    
int low=0,high=len-1,mid;
    
while(low<=high){
        mid
=(low+high)>>1;
        
if(x[mid]==h) return mid;
        
else if(x[mid]>h) high=mid-1;
        
else low=mid+1;
    }

    
return -1;
}

void create(int l,int r,int index){
    tree[index].left
=l,tree[index].right=r;
    tree[index].h
=0;
    
if(r==l+1return;
    
int mid=(l+r)>>1;
    create(l,mid,
2*index);
    create(mid,r,
2*index+1);
}

void update(int l,int r,int h,int index){
    
if(h<tree[index].h) return;
    
if(l==tree[index].left && r==tree[index].right){
        tree[index].h
=h;
        
return;
    }

    
if(tree[index].h>=0 && tree[index].right>tree[index].left+1){
        tree[
2*index].h=tree[2*index+1].h=tree[index].h;
        tree[index].h
=-1;
    }

    
int mid=(tree[index].left+tree[index].right)>>1;
    
if(r<=mid)
        update(l,r,h,
2*index);
    
else if(l>=mid)
        update(l,r,h,
2*index+1);
    
else{
        update(l,mid,h,
2*index);
        update(mid,r,h,
2*index+1);
    }

}

long long cal(int index){
    
if(tree[index].h>=0)
        
return tree[index].h*(long long)(x[tree[index].right]-x[tree[index].left]);
    
else
        
return cal(2*index)+cal(2*index+1);
}

int main(){
    
int n,i,k,l,r;
    scanf(
"%d",&n);
    
for(i=len=0;i<n;i++,len+=2){
        scanf(
"%d %d %d",&pos[i][0],&pos[i][1],&pos[i][2]);
        x[len]
=pos[i][0],x[len+1]=pos[i][1];
    }

    qsort(x,
2*n,sizeof(int),cmp1);
    
for(i=1,k=0;i<2*n;i++)
        
if(x[i]!=x[i-1]) x[k++]=x[i-1];
    x[k
++]=x[i-1],len=k;
    qsort(pos,n,
3*sizeof(int),cmp2);
    create(
0,len-1,1);
    
for(i=0;i<n;i++){
        l
=query(pos[i][0]),r=query(pos[i][1]);
        update(l,r,pos[i][
2],1);
    }

    printf(
"%I64d\n",cal(1));
    
return 0;
}

posted on 2009-05-13 15:50 極限定律 閱讀(919) 評論(0)  編輯 收藏 引用 所屬分類: ACM/ICPC

<2009年5月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

導航

統計

常用鏈接

留言簿(10)

隨筆分類

隨筆檔案

友情鏈接

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美承认网站| 久久er99精品| 亚洲另类自拍| 亚洲精品久久久久久下一站 | 麻豆免费精品视频| 久久九九国产精品怡红院| 国内自拍一区| 亚洲电影免费| 香蕉av777xxx色综合一区| 国产日本亚洲高清| 嫩草影视亚洲| 欧美日韩1区2区| 欧美一区二区日韩| 久久亚洲风情| 一区二区三区欧美成人| 六月丁香综合| 欧美日韩成人综合天天影院| 午夜亚洲福利在线老司机| 久久久久久久一区| 国产日韩综合| 亚洲国产成人久久综合一区| 国产精品久久久久久久久久免费 | 亚洲黄色有码视频| 欧美午夜在线视频| 免费看的黄色欧美网站| 欧美日韩视频在线| 久久综合九色| 国产精品igao视频网网址不卡日韩| 亚洲国产导航| 亚洲五月六月| 亚洲美女黄色| 亚洲欧洲一区| 欧美在线视频观看| 亚洲一级二级| 欧美jizzhd精品欧美巨大免费| 国产精品自拍小视频| 亚洲免费中文| 国产精品爽爽爽| 久久综合色8888| 亚洲欧美日韩在线高清直播| 欧美久久视频| 久久综合综合久久综合| 国产精品美女久久福利网站| 亚洲第一狼人社区| 国产日韩一区| 亚洲一区二区三区777| 日韩一区二区精品视频| 久久久久久噜噜噜久久久精品| 国内精品美女av在线播放| 99精品视频网| 中文国产一区| 亚洲一卡二卡三卡四卡五卡| 亚洲靠逼com| 美女视频黄 久久| 久久香蕉国产线看观看网| 国产日韩欧美91| 99av国产精品欲麻豆| 国产精品多人| 国产一区二区三区在线观看精品| 国产精品免费视频观看| 久久综合九色欧美综合狠狠| 国产乱码精品一区二区三区av| 久久九九免费| 国产日韩在线视频| 亚洲欧美在线网| 久久精品亚洲| 国内精品视频在线播放| 久久精品人人| 女女同性精品视频| 亚洲人妖在线| 欧美精品久久一区二区| 最新国产乱人伦偷精品免费网站| 国产精品日韩在线| 亚洲综合国产| 久久久综合视频| 亚洲韩国日本中文字幕| 欧美破处大片在线视频| 久久免费精品视频| 亚洲一区二区三区在线看| 日韩一级精品视频在线观看| 国产精品高潮呻吟| 亚洲一区二区三区国产| 欧美一区二区在线| 影音先锋亚洲视频| 欧美高清自拍一区| 亚洲午夜久久久久久久久电影院| 伊人一区二区三区久久精品| 免费高清在线一区| 欧美激情aⅴ一区二区三区| 一区二区免费看| 国产美女在线精品免费观看| 久久久亚洲成人| 亚洲精品黄色| 欧美一区亚洲一区| 亚洲精品美女久久7777777| 久久夜色撩人精品| 99视频+国产日韩欧美| 国产精品免费久久久久久| 久久在线视频在线| 欧美激情视频一区二区三区免费| 亚洲永久网站| 在线视频欧美日韩| 欧美一级二级三级蜜桃| 韩国三级电影久久久久久| 欧美国产日韩一区二区在线观看 | 韩国av一区二区三区四区| 中文日韩电影网站| 免费亚洲一区| 亚洲男人的天堂在线| 亚洲国产cao| 国产精品视频久久久| 欧美电影免费观看网站| 性做久久久久久免费观看欧美| 亚洲欧美国产精品专区久久| 在线不卡中文字幕| 国产精品一区二区三区四区| 欧美韩国一区| 久久亚洲精品欧美| 亚洲国产清纯| 亚洲第一免费播放区| **欧美日韩vr在线| 国产精品日韩| 欧美日韩一区视频| 欧美电影免费观看高清| 久久免费偷拍视频| 欧美一区二区成人| 亚洲欧美国产三级| 亚洲少妇自拍| 一区二区三区欧美| 日韩视频在线观看国产| 亚洲人体大胆视频| 亚洲第一福利在线观看| 欧美电影免费观看大全| 免费短视频成人日韩| 久久久爽爽爽美女图片| 久久精品亚洲国产奇米99| 性欧美暴力猛交另类hd| 亚洲男人的天堂在线| 亚洲一区二区三区四区五区黄| 欧美视频在线观看一区| 欧美黄色一区二区| 欧美激情精品久久久久久久变态| avtt综合网| 亚洲视屏一区| 亚洲国产精品久久久久秋霞蜜臀 | 国产欧美韩国高清| 国产精品日日做人人爱| 国产精品毛片va一区二区三区 | 久久夜色精品国产亚洲aⅴ| 亚洲男人第一av网站| 亚洲欧美国产一区二区三区| 亚洲欧美综合网| 久久精品中文| 蜜月aⅴ免费一区二区三区 | 日韩午夜av电影| 日韩写真视频在线观看| 亚洲图片欧美午夜| 欧美一区二区三区视频免费| 久久久久国产精品厨房| 免费在线观看一区二区| 亚洲全部视频| 亚洲免费在线视频| 欧美成年人视频网站欧美| 亚洲黄色大片| 亚洲一区欧美| 久久久久久婷| 欧美色大人视频| 国产一区二区激情| 亚洲精品一区二区三区福利| 亚洲专区免费| 麻豆精品一区二区av白丝在线| 亚洲一区二区视频| 久久精品国产99国产精品澳门| 一区二区三区 在线观看视| 国产一区二区三区黄视频| 亚洲国产成人不卡| 午夜精品电影| 老司机午夜精品视频在线观看| 性伦欧美刺激片在线观看| 夜夜嗨av一区二区三区免费区| 狠狠噜噜久久| 亚洲视频自拍偷拍| 久久夜色精品亚洲噜噜国产mv| 六月天综合网| 国产精品v欧美精品v日本精品动漫 | 日韩视频在线一区二区三区| 欧美在线观看视频在线| 欧美激情精品久久久久| 校园春色综合网| 欧美日本不卡高清| 亚洲高清视频的网址| 久久国产手机看片| 99国产精品久久久| 亚洲理论电影网| 久久亚洲欧美| 国产综合自拍| 欧美一区二区三区在线| 亚洲精品在线视频| 99国产一区| 欧美成人dvd在线视频|