zoukankan      html  css  js  c++  java
  • HDU 1255 覆盖的面积 线段树+扫描线

    同 POJ1151 这次是两次

    #include <iostream>
    #include <algorithm>
    #include <cstdio>
    #include <cstdlib>
    #include <cstring>
    #include <string>
    #include <stack>
    #include <queue>
    #include <cmath>
    #include <vector>
    using namespace std;
    const int N=1100;
    double y[N<<1];
    struct Line
    {
        int co;
        double x,y1,y2;
        void fun(double a,double b,double c,int d)
        {
            x=a;
            y1=b;
            y2=c;
            co=d;
        }
        bool operator<(const Line &e)const
        {
            return x<e.x;
        }
    }line[N*2];
    struct Node
    {
        double s,t,len;
        int co;
        void change(int o)
        {
            co+=o;
            if(co<2) len=0;
            else len=t-s;
        }
    };
    struct Segtree
    {
        Node tree[N*8];
        void build(int l,int r,int o)
        {
           tree[o].s=y[l];tree[o].t=y[r];
           tree[o].co=0;tree[o].len=0;
           if(l+1<r)
           {
              int m=(l+r)>>1;
              build(l,m,o*2);
              build(m,r,o*2+1);
           }
        }
        void pushup(int o)
        {
          tree[o].len=tree[o*2].len+tree[o*2+1].len;
        }
        void update(int l,int r,int o,Line e)
        {
            if(l+1==r)
            {
               tree[o].change(e.co);
               return;
            }
            int m=(l+r)>>1;
            if(e.y1<tree[o*2].t)update(l,m,o*2,e);
            if(e.y2>tree[o*2+1].s)update(m,r,o*2+1,e);
            pushup(o);
        }
    }seg;
    int main()
    {
        int n,T;
        scanf("%d",&T);
        while(T--)
        {
            scanf("%d",&n);
            int cnt=0;
            for(int i=0;i<n;i++)
            {
                double x1,x2,y1,y2;
                scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2);
                line[++cnt].fun(x1,y1,y2,1);
                y[cnt]=y1;
                line[++cnt].fun(x2,y1,y2,-1);
                y[cnt]=y2;
            }
            sort(line+1,line+cnt+1);
            sort(y+1,y+cnt+1);
            int d=1;
            for(int i=2;i<=cnt;i++)
               if(y[i]!=y[i-1])y[++d]=y[i];
            double ans=0;
            seg.build(1,d,1);
            seg.update(1,d,1,line[1]);
            for(int i=2;i<=cnt;i++)
            {
               ans+=(line[i].x-line[i-1].x)*seg.tree[1].len;
               seg.update(1,d,1,line[i]);
            }
            printf("%.2f
    ",ans);
        }
        return 0;
    }
    View Code
  • 相关阅读:
    失业状态,整理一下近期的面试问题 -- 直面自我
    nginx 学习 查一天不如问一句
    (10)kendo UI使用基础介绍与问题整理——MultiSelect
    kendo常用的实用方法(肯定有用得上的)
    (9)kendo UI使用基础介绍与问题整理——numerictextbox/基础说明
    去掉小数点后无效的0
    cmakelists编写样例
    visio 设计
    优化压测
    (转)语音处理基础知识
  • 原文地址:https://www.cnblogs.com/shuguangzw/p/5475447.html
Copyright © 2011-2022 走看看