POJ 1389 Area of Simple Polygons | 扫描线
#include<cstdio>
#include<algorithm>
#include<cstring>
#define N 1010
#define LEN 60010
using namespace std;
struct Edge
{
int l,r,h,f;
bool operator < (const Edge &a) const
{
if (h==a.h) return f<a.f;
return h<a.h;
}
}edge[N*];
int cnt,s[*LEN],cover[*LEN],mx;
//cover[i]表示节点i代表区间被覆盖的次数(可以重复覆盖)
//s[i]表示节点i代表区间被覆盖长度(不可重复)
long long ans;
void insert(int i,int l,int r,int x,int y,int k)
{
if (y<l || x>r) return;
if (x<=l && y>=r)
{
cover[i]+=k;
if (cover[i]>) s[i]=r-l+;//当cover大于0,区间一定被全覆盖
else if (l==r) s[i]=;
else s[i]=s[i*]+s[i*+];
return;
}
int mid=(l+r)>>;
insert(i*,l,mid,x,y,k);
insert(i*+,mid+,r,x,y,k);
if (cover[i]==) s[i]=s[*i]+s[*i+];//cover等于0就从左儿子和右儿子更新
return;
}
Edge make(int a,int b,int c,int d)
{
Edge ret;
ret.l=a,ret.r=b,ret.h=c,ret.f=d;
return ret;
}
int main()
{
int a,b,c,d;
while ()
{
cnt=ans=mx=;
while ()
{
scanf("%d%d%d%d",&a,&b,&c,&d);
mx=max(mx,c);
if (a==- && b==- && c==- && b==-) break;
edge[++cnt]=make(a,c,b,);
edge[++cnt]=make(a,c,d,-);
}
if (cnt==) break;
memset(cover,,sizeof(cover));
memset(s,,sizeof(s));
sort(edge+,edge++cnt);
insert(,,mx,edge[].l+,edge[].r,edge[].f);
for (int i=;i<=cnt;i++)
ans+=s[]*(edge[i].h-edge[i-].h),insert(,,mx,edge[i].l+,edge[i].r,edge[i].f);
printf("%lld\n",ans);
}
return ;
}
POJ 1389 Area of Simple Polygons | 扫描线的更多相关文章
- POJ 1389 Area of Simple Polygons 扫描线+线段树面积并
---恢复内容开始--- LINK 题意:同POJ1151 思路: /** @Date : 2017-07-19 13:24:45 * @FileName: POJ 1389 线段树+扫描线+面积并 ...
- [poj] 1389 Area of Simple Polygons
原题 线段树+扫描线 对于这样一个不规则图形,我们要求他的面积有两种方法,割和补. 补显然不行,因为补完你需要求补上去的内部分不规则图形面积-- 那么怎么割呢? 像这样: 我们就转化成了无数个矩形的和 ...
- POJ Area of Simple Polygons 扫描线
这个题lba等神犇说可以不用离散化,但是我就是要用. 题干: Description There are N, <= N <= , rectangles -D xy-plane. The ...
- POJ1389:Area of Simple Polygons——扫描线线段树题解+全套代码注释
http://poj.org/problem?id=1389 题面描述在二维xy平面中有N,1 <= N <= 1,000个矩形.矩形的四边是水平或垂直线段.矩形由左下角和右上角的点定义. ...
- 【POJ 1389】Area of Simple Polygons(线段树+扫描线,矩形并面积)
离散化后,[1,10]=[1,3]+[6,10]就丢了[4,5]这一段了. 因为更新[3,6]时,它只更新到[3,3],[6,6]. 要么在相差大于1的两点间加入一个值,要么就让左右端点为l,r的线段 ...
- Area of Simple Polygons
poj1389:http://poj.org/problem?id=1389 题意:求矩形面积的并题解:扫描线加线段树 同poj1389 #include<iostream> #inclu ...
- POJ1389 Area of Simple Polygons 线段树
POJ1389 给定n个整数点矩形,求面积并. 显然ans必然是整数. 记录若干个事件,每个矩形的左边的竖边记为开始,右边的竖边记为结束. 进行坐标离散化后用线段树维护每个竖的区间, 就可以快速积分了 ...
- poj 1389(离散化+计算几何)
Area of Simple Polygons Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 3412 Accepted ...
- poj 1265 Area 面积+多边形内点数
Area Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 5861 Accepted: 2612 Description ...
随机推荐
- Linux下 tar 命令详解
tar 是 unix/linux下的打包器 [解压] 输入命令: # tar -zxvf filename.tar.gz 参数解释: z :表示 tar 包是被 gzip 压缩过的 (后缀是.ta ...
- 使用MyEclipse/Eclipse修改项目名称报Can't convert argument: null!
报错: java.lang.IllegalArgumentException: Can't convert argument: null! 方法/步骤 报错原因:使用MyEclipse修改项目名 ...
- react native "Unable to resolve module `AccessibilityInfo`
error: bundling failed: "Unable to resolve module `AccessibilityInfo` from `/Users/apple/Websto ...
- A Country on Wheels【车轮上的国家】
A Country on Wheels As cultural symbols go, the American car is quite young. 作为文化象征的美国汽车还相当年轻. The ...
- [Bzoj1034][ZJOI2008]泡泡堂BNB(贪心)
Description 题目链接 Solution 这题就是一个贪心, 如果最弱的能赢对方最弱的就赢 否则最强的能赢对面最强的就赢 否则最弱的换对面最强 Code #include <cstdi ...
- python使用网易邮箱发邮件
# -*- coding: UTF-8 -*- import smtplib from email.mime.text import MIMEText import email.mime.multip ...
- 20145202 《信息安全系统设计基础》git安装
git的安装 直接输入指令将其安装就可以了. 安装的时候要设置公钥,我不知道以前在windows上设置过的公钥是否还能用所以我就还是从新搞了一个. 验证可以连通 遇到的问题
- Quartus 11生成pof文件在AS烧写之后,程序无法启动
1. 首先配置成AS,生成.pof文件,选择上面的图标Device 2. 选择Device and Pin Options... 3. 进入配置界面,选择如下 4. 进入下载界面,烧写.pof文件,开 ...
- Internet接入方式
(转载) 接入网可以大概分成两类:拨号上网(包括ASDL)与专线上网 在接入网中,目前可供选择的接入方式主要有PSTN.ISDN.DDN.LAN.ADSL.VDSL.Cable-Modem.PON和L ...
- DbVisualizer 解决中文乱码问题
在SQL Commander中,sql语句中如果有中文,显示是‘口口口’. 解决办法如下: 在Tools->tool Properties->General->Appearance- ...