codevs 3044 矩形面积求并
3044 矩形面积求并
输入n个矩形,求他们总共占地面积(也就是求一下面积的并)
可能有多组数据,读到n=0为止(不超过15组)
每组数据第一行一个数n,表示矩形个数(n<=100)
接下来n行每行4个实数x1,y1,x2,y1(0 <= x1 < x2 <= 100000;0 <= y1 < y2 <= 100000),表示矩形的左下角坐标和右上角坐标
每组数据输出一行表示答案
2
10 10 20 20
15 15 25 25.5
0
180.00
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define maxn 210
using namespace std;
struct node{
double l,r,h;int d;
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;
}
}a[maxn];
int cnt[maxn*],n;
double sum[maxn*],all[maxn];
void pushup(int l,int r,int k){
if(cnt[k])sum[k]=all[r+]-all[l];
else if(l==r)sum[k]=;
else sum[k]=sum[k<<]+sum[k<<|];
}
void update(int opl,int opr,int opv,int l,int r,int k){
if(l>=opl&&r<=opr){
cnt[k]+=opv;
pushup(l,r,k);
return;
}
int mid=(l+r)>>;
if(opl<=mid)update(opl,opr,opv,l,mid,k<<);
if(opr>mid)update(opl,opr,opv,mid+,r,k<<|);
pushup(l,r,k);
}
int main(){
while(){
scanf("%d",&n);
if(n==)return ;
double x1,x2,y1,y2;
for(int i=;i<=n;i++){
scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2);
a[i]=node(x1,x2,y1,);
a[i+n]=node(x1,x2,y2,-);
all[i]=x1;all[i+n]=x2;
}
n<<=;
sort(a+,a+n+);
sort(all+,all+n+);
int m=unique(all+,all+n+)-all-;
memset(cnt,,sizeof(cnt));
memset(sum,,sizeof(sum));
double ans=;
for(int i=;i<n;i++){
int l=lower_bound(all+,all+m+,a[i].l)-all;
int r=lower_bound(all+,all+m+,a[i].r)-all;
if(l<r)update(l,r-,a[i].d,,m,);
ans+=sum[]*(a[i+].h-a[i].h);
}
printf("%.2lf\n",ans);
}
return ;
}
codevs 3044 矩形面积求并的更多相关文章
- poj1151==codevs 3044 矩形面积求并
		
Atlantis Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 21511 Accepted: 8110 Descrip ...
 - codevs 3044 矩形面积求并 (扫描线)
		
/* 之前一直偷懒离散化+暴力做着题 今天搞一下扫描线 自己按照线段树的一般写法写的有些问题 因为不用于以前的区间sum so 题解搬运者23333 Orz~ 去掉了打标记的过程 同时更新区间的时候先 ...
 - codevs 3044 矩形面积求并 || hdu 1542
		
这个线段树的作用其实是维护一组(1维 平面(?) 上的)线段覆盖的区域的总长度,支持加入/删除一条线段. 线段树只能维护整数下标,因此要离散化. 也可以理解为将每一条处理的线段分解为一些小线段,要求每 ...
 - codves 3044 矩形面积求并
		
codves 3044 矩形面积求并 题目等级 : 钻石 Diamond 题目描述 Description 输入n个矩形,求他们总共占地面积(也就是求一下面积的并) 输入描述 Input Desc ...
 - 【题解】codevs 3044 矩形面积合并
		
传送门 3044 矩形面积求并 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题目描述 Description 输入n个矩形,求他们总共占地面积(也就是求一下 ...
 - 3044 矩形面积求并 - Wikioi
		
题目描述 Description 输入n个矩形,求他们总共占地面积(也就是求一下面积的并) 输入描述 Input Description 可能有多组数据,读到n=0为止(不超过15组) 每组数据第一行 ...
 - [Codevs] 矩形面积求并
		
http://codevs.cn/problem/3044/ 线段树扫描线矩形面积求并 基本思路就是将每个矩形的长(平行于x轴的边)投影到线段树上 下边+1,上边-1: 然后根据线段树的权值和与相邻两 ...
 - [codevs3044][POJ1151]矩形面积求并
		
[codevs3044][POJ1151]矩形面积求并 试题描述 输入n个矩形,求他们总共占地面积(也就是求一下面积的并) 输入 可能有多组数据,读到n=0为止(不超过15组) 每组数据第一行一个数n ...
 - 矩形面积求并(codevs 3044)
		
题目描述 Description 输入n个矩形,求他们总共占地面积(也就是求一下面积的并) 输入描述 Input Description 可能有多组数据,读到n=0为止(不超过15组) 每组数据第一行 ...
 
随机推荐
- python's fifteenth day for me  递归函数
			
递归... def age(n): if n == 1: return 18 else: return age(n-1)+2 # 反复调用函数age() print(age(4)) l = [1,3, ...
 - 用cascade删除有约束的表或记录
			
删除有约束的表 Drop table TERMPRO_RULE_ROUTE_TYPE cascade constraints:
 - pl/sql的to_char和to_date
			
今天同事让笔者将sql查询出来的时间转换为指定格式的字符串,笔者当时懵逼了,印象中记得有处理过,但就是一时想不起来了,等处理了这个问题后,笔者觉得有必要记录一下,毕竟不知道这个是很掉面子的事不是?好了 ...
 - Java中包、类、方法、属性、常量的命名规则
			
1:包(package):用于将完成不同功能的类分门别类,放在不同的目录(包)下,包的命名规则:将公司域名反转作为包名.比如www.baidu.com 对于包名:每个字母都需要小写.比如:com.ba ...
 - BP算法的推导
			
反向传播算法的推导 如图为2-layers CNN,输入单元下标为i,数量d:隐层单元下表j,数量\(n_H\):输出层下表k,单元数量c 1.目标 调整权系数\(w_{ji}\),\(w_{kj}\ ...
 - @RequestParam注解的作用
			
1.这个注解是干什么的??? 提取和解析请求参数的能力. 2.实例解析: a.代码 @Controller @RequestMapping("/pets") @SessionAtt ...
 - AOP操作术语
 - [luogu3369]普通平衡树(fhq-treap模板)
			
解题关键:无旋treap模板. #include<iostream> #include<cstdio> #include<cstring> #include< ...
 - libevent源码深度剖析十二
			
libevent源码深度剖析十二 ——让libevent支持多线程 张亮 Libevent本身不是多线程安全的,在多核的时代,如何能充分利用CPU的能力呢,这一节来说说如何在多线程环境中使用libev ...
 - 使用百度翻译的API接口
			
http://api.fanyi.baidu.com/api/trans/product/desktop 这是申请的接口地址,会得到一个APPID和一个钥密 然后下载PHP的对应的代码 有一个PHP文 ...