hdu1542矩阵的并 线段树+扫描线
求矩阵的并,也就是要求所有的面积。那可以吧总的图形按照矩阵来切割。使其为一块一块。
输入的时候用坐标表示,这里扫描线从下到上扫描。初始时让下面的边为1,上面的为-1;
用一条先从下面开始想上扫描。遇到更新线段树,加入该条边,为-1时就除去改变。
这样从下到上一遍扫描就可以得到线段的长度。从下到上的过程中,一旦遇到一条边,那就计算他的高度。
高度*长度就是面积。
/*
那叶子节点[l,l]的长度不就变成0,显然这是有问题的
线段树的每一个节点表示一段区间,[l,r]该区间表示LX[r+1]-LX[l]的长度
1___2___3___4___5离散后的状况
1 2 3 4 线段树中的每一个节点
*/
#include<stdio.h>
#include<string.h>
#include<iostream>
#include<algorithm>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define maxn 1005
double x[maxn<<];
struct seg
{
double l,r,h;
int f;
}s[maxn<<];
struct node
{
int cnt;//cnt表示该区间是否被完全覆盖 如果cnt==1表示被完全覆盖一次
//cnt=0表示为被完全覆盖 但是不代表未覆盖,cnt>1表示被多次完全覆盖
double len;
}tree[maxn*];
bool cmp(seg a,seg b)
{
return a.h<b.h;
}
int find(double val,int l,int r)
{
int left=l,right=r;
int mid;
while(left<=right)
{
mid=(left+right)/;
if(x[mid]==val)
return mid;
else if(x[mid]>val)
right=mid-;
else left=mid+;
}
return -;
}
void build(int l,int r,int rt)
{
if(l==r)
{
tree[rt].cnt=;
tree[rt].len=;
return ;
}
int m=(l+r)/;
build(lson);
build(rson);
}
void getlen(int rt,int l,int r)
{
if(tree[rt].cnt)//如果整一段被覆盖,直接求得长度
{
tree[rt].len=x[r+]-x[l];
}
else if(l==r)//叶子节点
tree[rt].len=;
else //不是叶子但也未整段覆盖,从儿子节点获得
tree[rt].len=tree[rt<<].len+tree[rt<<|].len;
}
void updata(int L,int R,int c,int l,int r,int rt)
{
if(l>=L&&R>=r)
{
tree[rt].cnt+=c;
getlen(rt,l,r);
return ;
}
int m=(l+r)/;
if(m>=L)
updata(L,R,c,lson);
if(R>m)
updata(L,R,c,rson);
getlen(rt,l,r);
}
int main()
{
int n,m,t,i,j,ff=;
double x1,x2,y1,y2;
while(scanf("%d",&n)!=EOF)
{
if(!n)
break;
m=;
for(i=;i<n;i++)
{
scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2);
s[m].l=x1;s[m].r=x2;s[m].h=y1;s[m].f=;
//下边界
s[m+].l=x1;s[m+].r=x2;s[m+].h=y2;s[m+].f=-;
//上边界
x[m]=x1;
x[m+]=x2;
m=m+;
}
sort(s,s+m,cmp);
sort(x,x+m);
int k=; for(i=;i<m;i++)//去重复
{
if(x[i]!=x[i-])
x[k++]=x[i];
} build(,k-,);
double ans=;
for(i=;i<m;i++)
{
int ll=find(s[i].l,,k-);//二分找位置
int rr=find(s[i].r,,k-)-;//因为这里表示的为线段 不是点。
updata(ll,rr,s[i].f,,k-,);
ans+=(s[i+].h-s[i].h)*tree[].len;
}
printf("Test case #%d\n",++ff);
printf("Total explored area: %.2lf\n\n",ans);
}
}
hdu1542矩阵的并 线段树+扫描线的更多相关文章
- hdu1255 矩阵的交 线段树+扫描线
/* 不是叶子节点 ,且cnt=1.注意这里,cnt=1确切的意义是什么, 应该是,可以确定,这个区间被完全覆盖了1次, 而有没有被完全覆盖两次或以上则不知道无法确定,那么怎么怎么办了, 只要加上t[ ...
- hdu1542 Atlantis 线段树--扫描线求面积并
There are several ancient Greek texts that contain descriptions of the fabled island Atlantis. Some ...
- hdu1542 Atlantis (线段树+扫描线+离散化)
Atlantis Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total S ...
- 线段树+扫描线【HDU1542】Atlantis
Description 给定一些二维空间上的矩形,求它们的面积并. 一道线段树+扫描线的板子题 然而即使我会打了,也不能灵活运用这种算法.QAQ 遇到题还是不太会. 但是这种板子题还是随随便便切的. ...
- hdu1542 线段树扫描线求矩形面积的并
题意: 给你n个正方形,求出他们的所占面积有多大,重叠的部分只能算一次. 思路: 自己的第一道线段树扫描线题目,至于扫描线,最近会写一个总结,现在就不直接在这里写了,说下我的方 ...
- hdu 4052 线段树扫描线、奇特处理
Adding New Machine Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- hdu 1828 线段树扫描线(周长)
Picture Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Sub ...
- HDU 6096 String 排序 + 线段树 + 扫描线
String Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 524288/524288 K (Java/Others) Problem De ...
- HDU 1828“Picture”(线段树+扫描线求矩形周长并)
传送门 •参考资料 [1]:算法总结:[线段树+扫描线]&矩形覆盖求面积/周长问题(HDU 1542/HDU 1828) •题意 给你 n 个矩形,求矩形并的周长: •题解1(两次扫描线) 周 ...
随机推荐
- 计算机网络: IP地址,子网掩码,默认网关,DNS服务器详解
楔子: 以Windows系统中IP地址设置界面为参考(如图1), IP地址, 子网掩码, 默认网关 和 DNS服务器, 这些都是什么意思呢? 学习IP地址的相关知识时还会遇到网络地址,广播地址,子网等 ...
- [树莓派]安装node环境
本文并非node的编译安装,据说这要花很长时间,所以一开始我就是拒绝的.本文展示的是如何部署ndoe的编译好的执行文件. node的官网上下载目录里本身就有针对arm的编译好的执行文件.地址在这里:h ...
- 第10章 同步设备I/O和异步设备I/O(4)_利用I/O完成端口实现Socket通信
I/O完成端口原理见上一篇(可点击这里) 10.5.4.4 利用I/O完成端口实现Socket通信 (1)Accept和AcceptEx流程的比较 ①采用accept方式的流程示意图如下(普通的阻塞函 ...
- 分层开发(MySchool总结)
由于分层之间存在各层之间的关系窗体之间的方法跳转,故有需要者可以进行下载本地文件 MySchool.rar 3304KB 5/22/2016 9:43:28 AM ,代码中有注释, 上述代码,属个人所 ...
- Css 常用属性
1. overflow:hidden和zoom:1 verflow:hidden;的作用 1. 隐藏溢出 :2.消除浮动 <style type="text/css"> ...
- 【WPF】WPF通过RelativeSource绑定父控件的属性
1.后台代码实现绑定父控件的属性 RelativeSource rs = new RelativeSource(RelativeSourceMode.FindAncestor); //设定为离自己控件 ...
- BPM到底能做什么?K2为你解读
和平镇,镇如其名,几百年来一直很和平,夜不闭户路不拾遗.可是这一年来,镇上金光寺的和尚却开始不断离奇死亡…… 衙门里新调来的李捕头正好负责这个案子,经过了几个月的不眠不休,现场侦查和缜密推理之后,一切 ...
- SOS.dll (SOS Debugging Extension)
SOS.dll (SOS Debugging Extension) lays threads associated with a live thread. The -special option di ...
- 本地环境,Ecshop安装教程
最近有个项目需要用ECshop来做,之前没接触过ECshop,今天去网上找了下安装教程,现在发出来分享一下. 1. ecshop网店系统最新版本是ECSHOP V2.7.3,去官网下载utf8和gbk ...
- MVC4项目中验证用户登录一个特性就搞定
在开发过程中,需要用户登陆才能访问指定的页面这种功能,微软已经提供了这个特性. // 摘要: // 表示一个特性,该特性用于限制调用方对操作方法的访问. [AttributeUsage(Attribu ...