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

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

PKU 2760 End of Windless Days

題目鏈接:http://poj.org/problem?id=2760
/*
題意:
    給出N(N <= 500)個不透明矩形和它的高度,矩形上方有一盞燈,
可以通過照射投影到地面上,不被矩形投影覆蓋的就會照亮,問最后照
亮的區域的面積。

解法:
離散化+線段樹

思路:
    如果我們知道每個矩形在地面的投影,那么這個問題就轉變成了求
矩形面積并的問題了,那么現在來看如何求一個矩形在地面的投影,可
以這樣想,這里問題簡化了,矩形必定和地面平行,所以是平行投影,
只會縮放,不會有透視效果,投影到地面上的還是矩形,然后考慮一維
的情況,一條線段在的投影,這個很簡單,只要利用三角形相似就可以
求出投影線段的兩端坐標,同樣,二維的情況也是類似,只需要xy兩維
分別做投影,當然這里的地面不是無窮大的,投影的矩形必須要和地面
的邊界求交,把所有的投影求出來后利用線段樹將所有矩形的面積并求
出來,然后用地面面積去減,就是最后照亮區域的面積了。
*/


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

#define maxn 2010
#define eps 1e-6


typedef 
double Type;

struct point {
    Type x, y;
    Type Height;
    point() 
{
        Height 
= 0;
    }

    
void SCANF_POINT() {
        
int tx, ty;
        scanf(
"%d %d"&tx, &ty);
        x 
= tx; y = ty;
    }

    
void SCANF_HEIGHT() {
        
int tmp;
        scanf(
"%d"&tmp);
        Height 
= tmp;
    }

}
;
point Min, Max, Light;

struct VLine {
    Type x, y0, y1;
    
int val;
    VLine() 
{}
    VLine(Type _x, Type _y0, Type _y1, 
int _v) {
        x 
= _x;
        y0 
= _y0;
        y1 
= _y1;
        val 
= _v;
    }

}
Vl[maxn*2];
int VlSize;
Type tmp[maxn];
int all, tot;

bool cmp(VLine a, VLine b) {
    
return a.x < b.x;
}


struct Rect {
    point L, R;

    
void SCANF() {
        L.SCANF_POINT();
        R.SCANF_POINT();

        L.SCANF_HEIGHT();
        R.Height 
= GetHeight();
    }


    Type GetHeight() 
{
        
return L.Height;
    }


    
bool ProjectionProcess();
}
Rec[maxn];

Type MMin(Type a, Type b) 
{
    
return a < b ? a : b;
}


Type MMax(Type a, Type b) 
{
    
return a > b ? a : b;
}


Type ProjectionCalculate(Type mx, Type mh, Type ux, Type uh) 
{
    
return ux - uh * (ux - mx) / (uh - mh);
}


bool Rect::ProjectionProcess() {
    L.x 
= MMax( Min.x, ProjectionCalculate(L.x, L.Height, Light.x, Light.Height));
    R.x 
= MMin( Max.x, ProjectionCalculate(R.x, R.Height, Light.x, Light.Height));

    L.y 
= MMax( Min.y, ProjectionCalculate(L.y, L.Height, Light.y, Light.Height));
    R.y 
= MMin( Max.y, ProjectionCalculate(R.y, R.Height, Light.y, Light.Height));

    
if(fabs(L.x - R.x) < eps || fabs(L.y - R.y) < eps)
        
return false;

    
return (L.x < R.x) && (L.y < R.y);
}


int Binary(double v) {
    
int l = 1;
    
int r = tot;
    
while(l <= r) {
        
int m = (l + r) >> 1;
        
if(fabs(tmp[m] - v) < eps)
            
return m;

        
if(v > tmp[m]) {
            l 
= m + 1;
        }
else
            r 
= m - 1;
    }

}


struct Tree {
    
int l, r;
    
int root;
    Type ylen;
    
int nCover;

    
void Update();
}
T[maxn*5];

void Tree::Update() {
    
if(nCover) {
        ylen 
= tmp[r] - tmp[l];
    }
else {
        
if(l + 1 == r)
            ylen 
= 0;
        
else
            ylen 
= T[root<<1].ylen + T[root<<1|1].ylen;
    }

}


void Build(int p, int l, int r) {
    T[p].l 
= l;
    T[p].root 
= p;
    T[p].r 
= r;
    T[p].nCover 
= 0;
    T[p].ylen 
= 0;
    
if(l + 1 == r) {
        
return ;
    }

    
int mid = (l + r) >> 1;
    Build(p
<<1, l, mid);
    Build(p
<<1|1, mid, r);
}


void Insert(int p, int l, int r, int val) {
    
if(l >= T[p].r || r <= T[p].l)
        
return ;

    
if(l <= T[p].l && T[p].r <= r) {
        T[p].nCover 
+= val;
        T[p].Update();
        
return ;
    }

    Insert(p
<<1, l, r, val);
    Insert(p
<<1|1, l, r, val);
    T[p].Update();
}


int n;
int main() {
    
int i;
    
while(scanf("%d"&n) != EOF) {
        Min.SCANF_POINT();
        Max.SCANF_POINT();
        Light.SCANF_POINT();
        Light.SCANF_HEIGHT();

        VlSize 
= 0;
        all 
= 1;
        tot 
= 0;

        
for(i = 0; i < n; i++{
            Rec[i].SCANF();
            
if( Rec[i].ProjectionProcess() ) {
                Vl[ VlSize 
++ ] = VLine(Rec[i].L.x, Rec[i].L.y, Rec[i].R.y, 1);
                Vl[ VlSize 
++ ] = VLine(Rec[i].R.x, Rec[i].L.y, Rec[i].R.y, -1);

                tmp[all
++= Rec[i].L.y;
                tmp[all
++= Rec[i].R.y;
            }

        }

        sort(tmp 
+ 1, tmp + all + 1);
        sort(Vl, Vl 
+ VlSize, cmp);

        
for(i = 1; i <= all; i++{
            
if(i==1 || fabs(tmp[i] - tmp[i-1]) > eps) {
                tmp[
++tot] = tmp[i];
            }

        }

        
double ans = (Max.x-Min.x) * (Max.y-Min.y);
        
if(tot >= 2{
            Build(
11, tot);
            
for(i = 0; i < VlSize; i++{
                
if(i) {
                    ans 
-= (Vl[i].x - Vl[i-1].x) * T[1].ylen;
                }

                Insert(
1, Binary(Vl[i].y0), Binary(Vl[i].y1), Vl[i].val);
            }

        }


        printf(
"%.4lf\n", ans);
    }

    
return 0;
}

posted on 2011-04-03 12:50 英雄哪里出來 閱讀(1144) 評論(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>
            一区二区三区精品视频| 亚洲人成啪啪网站| 久久久久国产一区二区三区四区 | 欧美伊人久久大香线蕉综合69| 一本色道久久88综合日韩精品| 亚洲日本乱码在线观看| 久久伊伊香蕉| 欧美国产视频在线观看| 亚洲精品免费在线观看| 日韩天堂在线视频| 亚洲欧美日韩综合国产aⅴ| 欧美影院在线| 欧美激情在线狂野欧美精品| 欧美三区美女| 国外视频精品毛片| 亚洲精品在线免费观看视频| 亚洲欧美精品中文字幕在线| 欧美伊人久久久久久久久影院| 久久只有精品| 日韩亚洲欧美一区| 久久久久久尹人网香蕉| 欧美日韩一区二区三区四区在线观看 | 亚洲精品永久免费| 性做久久久久久| 欧美黄免费看| 国产亚洲综合精品| aⅴ色国产欧美| 久久夜色精品| 一区二区三区成人精品| 久久久五月天| 国产欧美一区二区三区久久人妖 | 亚洲人体影院| 欧美一区成人| 欧美日韩一区二区免费在线观看| 国内精品视频666| 亚洲一本视频| 欧美黄在线观看| 久久爱www久久做| 欧美亚日韩国产aⅴ精品中极品| 国外成人在线| 久久激情中文| 亚洲一二三区视频在线观看| 欧美福利视频一区| 亚洲第一在线综合网站| 久久国产婷婷国产香蕉| 亚洲神马久久| 欧美午夜视频| 中文日韩在线| 亚洲乱码国产乱码精品精可以看| 麻豆成人在线| 亚洲激情成人在线| 欧美大片在线观看一区| 欧美在线视频日韩| 国产一区二区精品久久99| 亚洲欧美日韩中文在线制服| 亚洲伦理中文字幕| 欧美精选一区| 一区二区三区精品久久久| 91久久精品久久国产性色也91 | 亚洲精品一区二区三区在线观看| 久久精精品视频| 国产一区二区三区免费观看| 欧美一区二区在线看| 亚洲专区一二三| 国产精品一区久久久久| 午夜精品一区二区三区在线| 亚洲少妇自拍| 国产亚洲一二三区| 狼人社综合社区| 看欧美日韩国产| 亚洲精品网站在线播放gif| 91久久国产综合久久蜜月精品| 欧美大成色www永久网站婷| 亚洲精品视频二区| 99re视频这里只有精品| 国产精品免费电影| 久久久久久日产精品| 久久五月婷婷丁香社区| 亚洲人成网在线播放| 日韩视频一区二区在线观看 | 91久久精品一区二区别| 91久久精品日日躁夜夜躁欧美 | 久久在线播放| 日韩一区二区精品葵司在线| 在线视频你懂得一区二区三区| 国产精品美女久久久久av超清 | 亚洲裸体在线观看| 一本久道久久综合中文字幕| 国产精品无码永久免费888| 久久欧美中文字幕| 欧美激情视频网站| 亚洲欧美在线观看| 久久人人爽国产| 在线视频精品| 久久精品视频在线| 一区二区三区精品视频在线观看| 亚洲欧美另类国产| 亚洲三级电影全部在线观看高清| 中文亚洲免费| 最新亚洲视频| 性感少妇一区| 亚洲视频1区| 久久尤物视频| 久久国产精品99国产| 欧美成人网在线| 久久久久国产精品午夜一区| 欧美连裤袜在线视频| 久久久久亚洲综合| 欧美午夜电影在线| 欧美激情五月| 韩国精品久久久999| 一本一本久久a久久精品牛牛影视| 激情文学综合丁香| 亚洲欧美卡通另类91av| 中日韩视频在线观看| 久久综合五月天婷婷伊人| 欧美一区二区黄| 欧美日韩在线一区二区| 欧美国产日韩一区二区在线观看| 国产欧美一区二区精品婷婷| 夜夜夜久久久| 99re视频这里只有精品| 久久天天狠狠| 久久久综合网站| 国产精品一区二区男女羞羞无遮挡| 亚洲国产精品美女| 亚洲国产成人在线播放| 性欧美video另类hd性玩具| 亚洲一区二区视频在线观看| 美女国产一区| 欧美1级日本1级| 在线观看久久av| 久久久久久999| 裸体歌舞表演一区二区 | 亚洲一区在线观看免费观看电影高清| 免费日本视频一区| 亚洲高清成人| 亚洲精品小视频| 欧美精品一区在线发布| 91久久精品国产| 亚洲性视频网站| 国产精品vvv| 亚洲嫩草精品久久| 久久精品在线| 樱桃成人精品视频在线播放| 久久久久国色av免费观看性色| 久久综合色播五月| 亚洲国产精品久久久久久女王| 麻豆91精品| 亚洲砖区区免费| 国产精品理论片| 午夜精品视频在线| 老司机免费视频一区二区三区 | 午夜亚洲性色视频| 国产精品久久波多野结衣| 亚洲一二三区精品| 久久男人资源视频| 亚洲精品人人| 国产精品久久久久久一区二区三区| 亚洲午夜精品久久久久久app| 欧美一级在线亚洲天堂| 一区二区三区在线免费观看| 欧美xx视频| 亚洲一二三区精品| 久久久亚洲国产天美传媒修理工| 亚洲电影激情视频网站| 欧美日韩视频在线观看一区二区三区| 亚洲专区在线| 亚洲第一福利在线观看| 亚洲欧美国产另类| 亚洲电影天堂av| 国产精品hd| 久久综合久久综合这里只有精品| 亚洲精品日韩综合观看成人91| 性欧美精品高清| 最近看过的日韩成人| 国产精品实拍| 欧美国产日本| 欧美亚洲视频在线看网址| 91久久精品美女高潮| 久久久免费观看视频| 亚洲特色特黄| 亚洲日本国产| 韩国av一区二区三区| 欧美特黄一级大片| 美国成人直播| 欧美一区二区在线| 这里只有精品电影| 亚洲国产精品一区二区尤物区| 欧美一级专区| 亚洲一区二区三区乱码aⅴ| 亚洲经典三级| 黑人一区二区三区四区五区| 欧美小视频在线| 欧美日本不卡| 欧美岛国在线观看| 久久免费高清视频| 久久av资源网| 午夜精品免费| 亚洲欧美国产精品桃花|