zoukankan      html  css  js  c++  java
  • POJ1151+线段树+扫描线

      1 /*
      2 线段树+扫描线+离散化
      3 求多个矩形的面积
      4 */
      5 #include<stdio.h>
      6 #include<string.h>
      7 #include<stdlib.h>
      8 #include<algorithm>
      9 #include<iostream>
     10 #include<queue>
     11 #include<stack>
     12 #include<math.h>
     13 #include<map>
     14 using namespace std;
     15 const int maxn = 105;
     16 const int maxm = 210;
     17 struct SegTree{
     18     int l,r;
     19     int cover;
     20     double L_val,R_val;
     21     double sum;
     22 }ST[ maxm<<2 ];
     23 struct Line{
     24     double x,y1,y2;
     25     bool InOut;
     26 }yLine[ maxm ];
     27 int cmp( Line a,Line b ){
     28     return a.x<b.x;
     29 }
     30 double yIndex[ maxm ];
     31 int GetIndex( double val,int cnt ){
     32     return lower_bound( yIndex,yIndex+cnt,val )-yIndex;
     33 }
     34 
     35 void build( int L,int R,int n ){
     36     ST[ n ].l = L;
     37     ST[ n ].r = R;
     38     ST[ n ].cover = 0;
     39     ST[ n ].sum = 0;
     40     ST[ n ].L_val = yIndex[ L ];
     41     ST[ n ].R_val = yIndex[ R ];
     42     if( R-L>1 ){
     43         int mid = (L+R)/2;
     44         build( L,mid,2*n );
     45         build( mid,R,2*n+1 );
     46     }
     47 }
     48 void PushUp( int n ){
     49     if( ST[ n ].cover>0 ){
     50         ST[ n ].sum = ST[ n ].R_val-ST[ n ].L_val;
     51     }
     52     else if( ST[ n ].r-ST[ n ].l>1 ){
     53         ST[ n ].sum = ST[ 2*n ].sum+ST[ 2*n+1 ].sum;
     54     }
     55     else
     56         ST[ n ].sum = 0;
     57 }
     58 void update( int left,int right,bool InOut,int n  ){
     59     if( left==ST[ n ].l&&right==ST[ n ].r ){
     60         if( InOut==true ){
     61             ST[ n ].cover++;
     62         }
     63         else{
     64             ST[ n ].cover--;
     65         }
     66     }
     67     else {
     68         int mid = (ST[ n ].l+ST[ n ].r)/2;
     69         if( mid>=right ) update( left,right,InOut,2*n );
     70         else if( mid<=left ) update( left,right,InOut,2*n+1 );
     71         else {
     72             update( left,mid,InOut,2*n );
     73             update( mid,right,InOut,2*n+1 );
     74         }
     75     }
     76     PushUp( n );
     77 }
     78 
     79 int main(){
     80     int n;
     81     int T = 1;
     82     while( scanf("%d",&n)==1,n ){
     83         printf("Test case #%d
    ",T++);
     84         double x1,y1,x2,y2;
     85         int cnt = 0;
     86         for( int i=0;i<n;i++ ){
     87             scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2);
     88             yLine[ 2*i ].x = x1;
     89             yLine[ 2*i+1 ].x = x2;
     90             yLine[ 2*i ].y1 = yLine[ 2*i+1 ].y1 = y1;
     91             yLine[ 2*i ].y2 = yLine[ 2*i+1 ].y2 = y2;
     92             yLine[ 2*i ].InOut = true;
     93             yLine[ 2*i+1 ].InOut = false;
     94             yIndex[ 2*i ] = y1;
     95             yIndex[ 2*i+1 ] = y2;
     96         }
     97         sort( yLine,yLine+2*n,cmp );
     98         sort( yIndex,yIndex+2*n );
     99         for( int i=1;i<2*n;i++ ){
    100             if( yIndex[i]!=yIndex[i-1] )
    101                 yIndex[ cnt++ ] = yIndex[ i-1 ];
    102         }
    103         yIndex[ cnt++ ] = yIndex[ 2*n-1 ];
    104         build( 0,cnt-1,1 );
    105         double res = 0;
    106         update( GetIndex( yLine[0].y1,cnt ),GetIndex( yLine[0].y2,cnt ),yLine[0].InOut,1 );
    107         for( int i=1;i<2*n;i++ ){
    108             res += ST[ 1 ].sum*( yLine[i].x-yLine[i-1].x );
    109             update( GetIndex( yLine[i].y1,cnt ),GetIndex( yLine[i].y2,cnt ),yLine[i].InOut,1 );
    110         }
    111         printf("Total explored area: %.2lf
    
    ",res);
    112     }
    113     return 0;
    114 }
    View Code
    keep moving...
  • 相关阅读:
    Eclipse的Debug教程
    Java面向对象--关键字(package、import、this)
    Java面向对象--JavaBean类&UML类图
    Java面向对象--构造器(构造方法)
    Java面向对象--属性和方法
    python | 基础知识与基本概念
    post登录 jsessionid 以及cookie 传递
    JMeter学习-017-java.net.SocketException: Permission denied: connect 解决方案
    python自建模块显示说明与详情
    在linux下pycharm无法输入中文
  • 原文地址:https://www.cnblogs.com/xxx0624/p/3275047.html
Copyright © 2011-2022 走看看