[codevs3044]矩形面积求并
|
题目描述 Description
|
|
输入n个矩形,求他们总共占地面积(也就是求一下面积的并)
|
|
输入描述 Input Description
|
|
可能有多组数据,读到n=0为止(不超过15组) 每组数据第一行一个数n,表示矩形个数(n<=100) 接下来n行每行4个实数x1,y1,x2,y1(0 <= x1 < x2 <= 100000;0 <= y1 < y2 <= 100000),表示矩形的左下角坐标和右上角坐标 |
|
输出描述 Output Description
|
|
每组数据输出一行表示答案
|
|
样例输入 Sample Input
|
|
2
10 10 20 20 15 15 25 25.5 0 |
|
样例输出 Sample Output
|
|
180.00
|
|
数据范围及提示 Data Size & Hint
|
|
无
|
矩形面积并,扫描线+线段树
本题的线段树比较奇怪
其中的坑点在pushup,线段树维护的区间[l,r]如果l,r相等并不是一段空集,而是线段pos[l]-pos[r+1] 这一线段
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<queue>
#include<cmath>
#include<cstring>
using namespace std;
typedef long long LL;
typedef pair<int,int> PII;
#define mem(a,b) memset(a,b,sizeof(a))
inline int read()
{
int x=,f=;char c=getchar();
while(!isdigit(c)){if(c=='-')f=-;c=getchar();}
while(isdigit(c)){x=x*+c-'';c=getchar();}
return x*f;
}
const int maxn=;
int n,add[maxn<<];
double a,b,c,d,pos[maxn],sum[maxn<<],ans;
struct segment
{
double X,x,Y;int tag;
segment(){}
segment(double _1,double _2,double _3,int _4):X(_1),x(_2),Y(_3),tag(_4) {}
bool operator < (const segment &s)const {return Y<s.Y;}
}seg[maxn];
void pushup(int l,int r,int o)
{
if(add[o])sum[o]=pos[r+]-pos[l];
else if(l==r)sum[o]=;
else sum[o]=sum[o<<]+sum[o<<|];
}
void update(int l,int r,int o,int L,int R,int c)
{
if(L==l && r==R)
{
add[o]+=c;
pushup(l,r,o);
return;
}
int mid=(l+r)>>,lo=o<<,ro=lo|;
if(R<=mid)update(l,mid,lo,L,R,c);
else if(L>mid)update(mid+,r,ro,L,R,c);
else update(l,mid,lo,L,mid,c),update(mid+,r,ro,mid+,R,c);
pushup(l,r,o);
}
int main()
{
while(scanf("%d",&n)!=EOF && n)
{
mem(pos,);mem(sum,);mem(add,);ans=;
for(int i=;i<=n;i++)
{
scanf("%lf%lf%lf%lf",&a,&b,&c,&d);
seg[i*]=segment(a,c,b,);pos[i*]=a;
seg[i*-]=segment(a,c,d,-);pos[i*-]=c;
}
sort(seg+,seg+n*+);sort(pos+,pos+n*+);
for(int i=;i<=*n;i++)
{
int l=lower_bound(pos+,pos+n*+,seg[i].X)-pos;
int r=lower_bound(pos+,pos+n*+,seg[i].x)-pos-;
update(,*n,,l,r,seg[i].tag);
ans+=sum[]*(seg[i+].Y-seg[i].Y);
}
printf("%.2lf\n",ans);
}
return ;
}
[codevs3044]矩形面积求并的更多相关文章
- [codevs3044][POJ1151]矩形面积求并
[codevs3044][POJ1151]矩形面积求并 试题描述 输入n个矩形,求他们总共占地面积(也就是求一下面积的并) 输入 可能有多组数据,读到n=0为止(不超过15组) 每组数据第一行一个数n ...
- codves 3044 矩形面积求并
codves 3044 矩形面积求并 题目等级 : 钻石 Diamond 题目描述 Description 输入n个矩形,求他们总共占地面积(也就是求一下面积的并) 输入描述 Input Desc ...
- codevs 3044 矩形面积求并
3044 矩形面积求并 题目描述 Description 输入n个矩形,求他们总共占地面积(也就是求一下面积的并) 输入描述 Input Description 可能有多组数据,读到n=0为止(不 ...
- [Codevs] 矩形面积求并
http://codevs.cn/problem/3044/ 线段树扫描线矩形面积求并 基本思路就是将每个矩形的长(平行于x轴的边)投影到线段树上 下边+1,上边-1: 然后根据线段树的权值和与相邻两 ...
- 3044 矩形面积求并 - Wikioi
题目描述 Description 输入n个矩形,求他们总共占地面积(也就是求一下面积的并) 输入描述 Input Description 可能有多组数据,读到n=0为止(不超过15组) 每组数据第一行 ...
- POJ 1151 Atlantis 矩形面积求交/线段树扫描线
Atlantis 题目连接 http://poj.org/problem?id=1151 Description here are several ancient Greek texts that c ...
- 矩形面积求并(codevs 3044)
题目描述 Description 输入n个矩形,求他们总共占地面积(也就是求一下面积的并) 输入描述 Input Description 可能有多组数据,读到n=0为止(不超过15组) 每组数据第一行 ...
- poj1151==codevs 3044 矩形面积求并
Atlantis Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 21511 Accepted: 8110 Descrip ...
- codevs 3044 矩形面积求并 (扫描线)
/* 之前一直偷懒离散化+暴力做着题 今天搞一下扫描线 自己按照线段树的一般写法写的有些问题 因为不用于以前的区间sum so 题解搬运者23333 Orz~ 去掉了打标记的过程 同时更新区间的时候先 ...
随机推荐
- 解决windows server 2008R2自动关机
原因:找到Windows Licensing Monitoring Service服务 是这服务在作祟,这服务是Windows软件许可状态.任务管理器查看有wlms.exe进程. 使用C:\Windo ...
- PHP 命名空间笔记
PHP 命名空间笔记 1.php文件代码如下<pre><?php//我用这样的命名空间表示处于blog下的article模块namespace Blog\Article; class ...
- Laravel手动分页的方法
use Illuminate\Pagination\LengthAwarePaginator; public function index(Request $request){ $list =[... ...
- Java8 新特性 Stream() API
新特性里面为什么要加入流Steam() 集合是Java中使用最多的API,几乎每一个Java程序都会制造和处理集合.集合对于很多程序都是必须的,但是如果一个集合进行,分组,排序,筛选,过滤...这些操 ...
- vins_fusion学习笔记
Vins-Fusion源码:https://github.com/HKUST-Aerial-Robotics/VINS-Fusion 摘要 应项目需要,侧重学习stereo+gps融合 转载几篇写的比 ...
- C语言语法教程-链表
链表是一群结构体(称为结点)通过指针连起来.这种结构体类型,比较特殊,叫自引用结构体类型.它有一个指针指向和和结构体一样的类型,其余是数据成员. 头指针指向第一结点,尾指针一定要用空表示,这叫有头有尾 ...
- RabbitMQ系列(二)环境搭建
参考: https://www.cnblogs.com/ericli-ericli/p/5902270.html https://blog.csdn.net/weixin_30619101/artic ...
- 处理 unassigned shard
#查看所有分片 GET _cat/shards curl 10.1.2.2:9200/_cat/indices/iis_log* #查看索引的分片状态 #查看第一个unassigned shard的 ...
- salesforce零基础学习(九十四)classic下pagelayout引入的vf page弹出内容更新此page layout
我们在classic环境中,有时针对page layout不能实现的地方,可以引入 一个vf page去增强标准的 page layout 功能,有时可能要求这个 vf page的部分修改需要更新此 ...
- 开发技术--pandas模块
开发|pandas模块 整了一篇关于pandas模块的使用文章,方便检查自己的学习质量.自从使用了pandas之后,真的是被它的功能所震撼~~~ 前言 目前所有的文章思想格式都是:知识+情感. 知识: ...