原题

线段树+扫描线

对于这样一个不规则图形,我们要求他的面积有两种方法,割和补。

补显然不行,因为补完你需要求补上去的内部分不规则图形面积……

那么怎么割呢?

像这样:

我们就转化成了无数个矩形的和。要想求这些矩形的面积,也就是底成高。因为我们并不懂什么二维线段树,所以我们就用“扫描线”(从左到右的更新计算)。

不妨把y轴当做一个线段树,然后维护哪些位置被覆盖了,直到下一条更新,所增加的面积就是被覆盖位置(高)和这两个距离的差(底)的乘积。

Eg:



我们第一次更新建了第一条边的树,第二次更新时就可以增加这么多的长度。

然后我们考虑这样一个情况,如果某个位置被覆盖了很多次怎么办,显然我们线段树的维护是不能将它重复计算多次的,那么我们就加一个cover数组,来记录当前区间被覆盖过多少次,那样在做下面这样的更新时就不会出错。

接下来来理解代码把~!

#include<cstdio>
#include<cstring>
#include<algorithm>
#define N 1010
#define M 60010
using namespace std;
int x1,y1,x2,y2,s[4*M],cov[4*M],ans,tot,mxy;
struct hhh
{
int x,yf,yb,k;
bool operator < (const hhh &b) const
{
if (x==b.x) return k<b.k;
return x<b.x;
}
}a[2*N]; int read()
{
int ans=0,fu=1;
char j=getchar();
for (;(j<'0' || j>'9') && j!='-';j=getchar()) ;
if (j=='-') j=getchar();
for (;j>='0' && j<='9';j=getchar()) ans*=10,ans+=j-'0';
return ans*fu;
} void modify(int i,int l,int r,int x,int y,int k)
{
if (x<=l && y>=r)
{
cov[i]+=k;
if (cov[i]) s[i]=r-l+1;
else if (l==r) s[i]=0;
else s[i]=s[i*2]+s[i*2+1];
}
else
{
int mid=(l+r)>>1;
if (x<=mid) modify(i*2,l,mid,x,y,k);
if (y>mid) modify(i*2+1,mid+1,r,x,y,k);
if (!cov[i]) s[i]=s[i*2]+s[i*2+1];
}
} int main()
{
while (~scanf("%d%d%d%d",&x1,&y1,&x2,&y2))
{
mxy=0;
tot=1;
if (x1==-1 && y1==-1 && x2==-1 && y2==-1) break;
memset(cov,0,sizeof(cov));
memset(s,0,sizeof(s));
while (1)
{
if (x1==-1 && y1==-1 && x2==-1 && y2==-1) break;
mxy=max(mxy,y2);
a[tot].x=x1;a[tot].yf=y1;a[tot].yb=y2;a[tot++].k=1;
a[tot].x=x2;a[tot].yf=y1;a[tot].yb=y2;a[tot++].k=-1;
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
}
sort(a+1,a+tot);
ans=0;
modify(1,0,mxy,a[1].yf+1,a[1].yb,a[1].k);
for (int i=2;i<tot;i++)
{
ans+=s[1]*(a[i].x-a[i-1].x);
modify(1,0,mxy,a[i].yf+1,a[i].yb,a[i].k);
}
printf("%d\n",ans);
}
return 0;
}

[poj] 1389 Area of Simple Polygons的更多相关文章

  1. POJ 1389 Area of Simple Polygons 扫描线+线段树面积并

    ---恢复内容开始--- LINK 题意:同POJ1151 思路: /** @Date : 2017-07-19 13:24:45 * @FileName: POJ 1389 线段树+扫描线+面积并 ...

  2. POJ 1389 Area of Simple Polygons | 扫描线

    请戳此处 #include<cstdio> #include<algorithm> #include<cstring> #define N 1010 #define ...

  3. POJ Area of Simple Polygons 扫描线

    这个题lba等神犇说可以不用离散化,但是我就是要用. 题干: Description There are N, <= N <= , rectangles -D xy-plane. The ...

  4. 【POJ 1389】Area of Simple Polygons(线段树+扫描线,矩形并面积)

    离散化后,[1,10]=[1,3]+[6,10]就丢了[4,5]这一段了. 因为更新[3,6]时,它只更新到[3,3],[6,6]. 要么在相差大于1的两点间加入一个值,要么就让左右端点为l,r的线段 ...

  5. Area of Simple Polygons

    poj1389:http://poj.org/problem?id=1389 题意:求矩形面积的并题解:扫描线加线段树 同poj1389 #include<iostream> #inclu ...

  6. POJ1389:Area of Simple Polygons——扫描线线段树题解+全套代码注释

    http://poj.org/problem?id=1389 题面描述在二维xy平面中有N,1 <= N <= 1,000个矩形.矩形的四边是水平或垂直线段.矩形由左下角和右上角的点定义. ...

  7. POJ1389 Area of Simple Polygons 线段树

    POJ1389 给定n个整数点矩形,求面积并. 显然ans必然是整数. 记录若干个事件,每个矩形的左边的竖边记为开始,右边的竖边记为结束. 进行坐标离散化后用线段树维护每个竖的区间, 就可以快速积分了 ...

  8. poj 1389(离散化+计算几何)

    Area of Simple Polygons Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 3412   Accepted ...

  9. poj 1265 Area 面积+多边形内点数

    Area Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 5861   Accepted: 2612 Description ...

随机推荐

  1. 总结JavaScript常用数组操作方法,包含ES6方法

    一.concat() concat() 方法用于连接两个或多个数组.该方法不会改变现有的数组,仅会返回被连接数组的一个副本. var arr1 = [1,2,3]; var arr2 = [4,5]; ...

  2. Hbase学习指南

    本篇Hbase组件基于CDH5进行安装,安装过程:https://www.cnblogs.com/dmjx/p/10037066.html Hbase简介 HBase是一个高可靠.高性能.面向列.可伸 ...

  3. Yii2实现跨mysql数据库关联查询排序功能

    遇到一个项目,需要跨表网上找了很多的资料,整理一下,方便以后再次使用 背景:在一个mysql服务器上(注意:两个数据库必须在同一个mysql服务器上)有两个数据库: memory (存储常规数据表) ...

  4. php-5.6.26源代码 - opcode处理器,“函数调用opcode”处理器,如何调用扩展模块的函数

    // opcode处理器 --- ZEND_DO_FCALL_SPEC_CONST_HANDLER实现在 php-5.6.26\Zend\zend_vm_execute.h static int ZE ...

  5. qt5.10.1编译记录

    qt版本更新比较快,不知道选哪个版本合适,故选择一个较新版本的. 平台imx6    +    linux4.1.16   +   qt5.10.1 采用明远智睿提供的编译器:fsl-imx-fb-g ...

  6. C语言进阶——变量属性05

    C语言变量属性: C语言的变量可以有自己的属性 在定义变量的时候加上“属性”关键字 “属性”关键字指明变量的特有意义 语法:property type value_name; auto关键字: aut ...

  7. Poweroj:2425-跳台阶(经典递推)

    题目链接:https://www.oj.swust.edu.cn/problem/show/2425 跳台阶 Edit Manage Data Rejudge Time Limit: 1000 MS ...

  8. Aizu:0189-Convenient Location

    Convenient Location Time limit 1000 ms Memory limit 131072 kB Problem Description 明年毕业的A为就业而搬家.就职的公司 ...

  9. CERC2017 F: Faulty Factorial 简单数论题

    #include <iostream> using namespace std; #define ll long long ; ll n,p,r; ll poww(ll a,ll b){ ...

  10. spark练习--统计xxx大学的各个少数名族的情况

    最近,有一份数据,是关于学校的数据,这个里面有所有学生的信息,今天闲来没事,我就想用spark的方式来读取文件,并且来统计这个学校的各个民族的情况,以前我用hadoop中mapReduce来计算,不得 ...