覆盖的面积

Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 30 Accepted Submission(s): 23
 
Problem Description
给定平面上若干矩形,求出被这些矩形覆盖过至少两次的区域的面积.

 
Input
输入数据的第一行是一个正整数T(1<=T<=100),代表测试数据的数量.每个测试数据的第一行是一个正整数N(1<=N<=1000),代表矩形的数量,然后是N行数据,每一行包含四个浮点数,代表平面上的一个矩形的左上角坐标和右下角坐标,矩形的上下边和X轴平行,左右边和Y轴平行.坐标的范围从0到100000.

注意:本题的输入数据较多,推荐使用scanf读入数据.

 
Output
对于每组测试数据,请计算出被这些矩形覆盖过至少两次的区域的面积.结果保留两位小数.
 
Sample Input
2
5
1 1 4 2
1 3 3 7
2 1.5 5 4.5
3.5 1.25 7.5 4
6 3 10 7
3
0 0 1 1
1 0 2 1
2 0 3 1
 
Sample Output
7.63
0.00
 
Author
Ignatius.L & weigang Lee
 
 
Recommend
Ignatius.L
 
/*----------------------------------------------
File: F:\ACM源代码\数据结构--线段树\HDU1255.cpp
Date: 2017/5/30 22:21:39
Author: LyuCheng
----------------------------------------------*/
/*
题意:给你很多矩形,然后让你求出最少覆盖两次的面积 思路:扫描线加一点扩展, 计算面积的时候,忽略覆盖一次的长度,x轴上覆盖超过两次的线段长度*高度
由于我们只需要维护1到max的覆盖长度,所以不需要向下更新,pushup函数,一次维护覆盖过一次的
长度,一次维护覆盖过两次或者以上的长度
*/ #include<bits/stdc++.h> #define N 2222
#define lson i*2,l,m
#define rson i*2+1,m+1,r
using namespace std; struct Node{
double l,r,h;
int d;//左右边界,y坐标,是上边界还是下边界
Node (){}
Node(double _l,double _r,double _h,int _d){l=_l;r=_r;h=_h;d=_d;}
bool operator < (const Node &b) const{
return h<b.h;
}
};
Node node[N*];//每一个矩形都能产生两条边
double X[N*];//一个矩形有两条边,一条边有两个在x轴上的坐标
double sum[N*];//表示覆盖过的长度
double sumd[N*];//表示覆盖过两次的以上的长度
int setd[N*]; void pushupo(int i,int l,int r){//更新覆盖过一次的
if(setd[i]){
sum[i]=X[r+]-X[l];
}else if(l==r){//如果是叶子结点的话,那么覆盖长度是零
sum[i]=;
}else{
sum[i]=sum[i*]+sum[i*+];
}
} void pushupm(int i,int l,int r){//更新覆盖过两次以上的
if(setd[i]>=){//覆盖过两次或者以上了
sumd[i]=X[r+]-X[l];
}else if(l==r){//叶子结点
sumd[i]=;
}else if(setd[i]==){
sumd[i]=sum[i*]+sum[i*+];
}else{
sumd[i]=sumd[i*]+sumd[i*+];
}
} void update(int ql,int qr,int d,int i,int l,int r){ if(ql<=l&&r<=qr){
setd[i]+=d;
pushupo(i,l,r);
pushupm(i,l,r);
return ;
} int m=l+(r-l)/;
if(ql<=m) update(ql,qr,d,lson);
if(m<qr) update(ql,qr,d,rson);
pushupo(i,l,r);
pushupm(i,l,r);
} int Seach(double op,int n){//离散化x坐标为整数,这样才能用线段树维护
int l=,r=n;
while(r>=l){
int m=l+(r-l)/;
if(X[m]==op)
return m;
else if(X[m]>op)
r=m-;
else
l=m+;
}
return -;
} void init(){
memset(sum,,sizeof sum);
memset(sumd,,sizeof sumd);
memset(setd,,sizeof setd);
} int main(){ // freopen("in.txt","r",stdin);
int n;
double x1,x2,y1,y2;
int len=;
int cnt=;
int t;
scanf("%d",&t);
while(t--){
init();
scanf("%d",&n);
len=;cnt=; for(int i=;i<=n;i++){
scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2);
node[++cnt]=Node(x1,x2,y1,);
node[++cnt]=Node(x1,x2,y2,-);
X[++len]=x1;
X[++len]=x2;
} sort(node+,node+cnt+);
sort(X+,X+len+); int ans=; for(int i=;i<=len;i++)//进行去重操作
if(X[i]!=X[i-])
X[++ans]=X[i]; len=ans;
double cur=;
for(int i=;i<cnt;i++){
int l=Seach(node[i].l,len);
int r=Seach(node[i].r,len)-;
if(l<=r)
update(l,r,node[i].d,,,len);
cur+=sumd[]*(node[i+].h-node[i].h);
}
printf("%.2lf\n",cur);
}
return ;
}

HDU1255覆盖的面积的更多相关文章

  1. Hdu1255 覆盖的面积

    覆盖的面积 Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Subm ...

  2. HDU1255 覆盖的面积 —— 求矩形交面积 线段树 + 扫描线 + 离散化

    题目链接:https://vjudge.net/problem/HDU-1255 给定平面上若干矩形,求出被这些矩形覆盖过至少两次的区域的面积. Input输入数据的第一行是一个正整数T(1<= ...

  3. HDU-1255 覆盖的面积 (扫描线)

    题目大意:给若干个矩形,统计重叠次数不为0的面积. 题目分析:维护扫描线的长度时,只需要只统计覆盖次数大于1的区间即可.这是个区间更新,不过不能使用懒标记,但是数据规模不大,不用懒惰标记仍可以AC. ...

  4. hdu1255 覆盖的面积 线段树+里离散化求矩形面积的交

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1255 求矩形面积的交的线段树题目,刚做了求并的题目,再做这个刚觉良好啊,只要再加一个表示覆盖次数大于1 ...

  5. HDU-1255 覆盖的面积 覆盖的矩形面积并

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1255 需要保存区间覆盖线>=2的线段的长度,根据情况来更新... //STATUS:C++_AC ...

  6. hdu1255 覆盖的面积 线段树-扫描线

    矩形面积并 线段树-扫描线裸题 #include<stdio.h> #include<string.h> #include<algorithm> #include& ...

  7. hdu1255 覆盖的面积(线段树面积交)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1255 面积交与面积并相似相比回了面积并,面积交一定会有思路,当然就是cover标记大于等于两次时. 但 ...

  8. 覆盖的面积(HDU 1255 线段树)

    覆盖的面积 Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Problem D ...

  9. hdu 1255 覆盖的面积(线段树 面积 交) (待整理)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1255 Description 给定平面上若干矩形,求出被这些矩形覆盖过至少两次的区域的面积.   In ...

随机推荐

  1. 开源API集成测试工具 Hitchhiker v0.1.3 - 参数化请求

    Hitchhiker 是一款开源的 Restful Api 集成测试工具,你可以轻松部署到本地,和你的team成员一起管理Api. 详细介绍请看: http://www.cnblogs.com/bro ...

  2. node.js express mvc轻量级框架实践

    本文记录的是笔者最近抽私下时间给朋友做的一个时时彩自动下注系统,比较简单,主要也是为了学习一下node.js. 其实逻辑没什么可以深谈的,主要是想说说这套代码结构.结构如下图: js的代码比较难以维护 ...

  3. Oracle的trim( )、ltrim( )、rtrim( )三个函数的用法及注意事项

    学习一下用法整理trim().ltrim().rtrim()的用法 trim().ltrim().rtrim()三个函数有两个作用,分别是: 一.去除字符串前后空格(基本用法) trim(string ...

  4. TTabControl

    1.TTabControl 组件的典型用法TTabControl 组件使用起来,根本不会使程序简单化,所以不提倡使用此组件,可以用TPageControl组件代替.与多页组件不同的是,虽然Tab 组件 ...

  5. Doing Homework again

     Doing Homework again Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I6 ...

  6. GCD hdu2588

    GCD Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  7. http://codeforces.com/contest/845

    A. Chess Tourney time limit per test 1 second memory limit per test 256 megabytes input standard inp ...

  8. BZOJ-1192-[HNOI2006]鬼谷子的钱袋

    Description 鬼谷子非常聪明,正因为这样,他非常繁忙,经常有各诸侯车的特派员前来向他咨询时政.有一天,他在咸阳游历的时候,朋友告诉他在咸阳最大的拍卖行(聚宝商行)将要举行一场拍卖会,其中有一 ...

  9. Tomcat 设置自启动时遇到的错误问题与解决方案

    首先,今天在做tomcat开机自启动时,原本很简单的一个问题,但却浪费了很长时间: 首先系统环境采用的是Window10,设置Tomcat自启动过程当中需要注意的是:JDK的版本和Tomcat的位数必 ...

  10. 数据的分类-JavaScript数据类型

    JavaScript数据类型 1.数据类型是什么? 我们接触的绝大多数程序语言来说,把数据都进行了分类,包括数字.字符.逻辑真假:int,long,string,boolean....等等:我们都知道 ...