【POJ1151】Atlantis(线段树,扫描线)

题面

Vjudge

题解

学一学扫描线

其实很简单啦

这道题目要求的就是若干矩形的面积和

把扫描线平行于某个轴扫过去(我选的平行\(y\)轴扫)

这样只需要求出每次和\(x\)轴覆盖的长度

就可以两两相乘,求出面积

最后累计和就行啦

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<set>
#include<map>
#include<vector>
#include<queue>
using namespace std;
#define ll long long
#define RG register
#define MAX 500
#define lson (now<<1)
#define rson (now<<1|1)
struct Node{double x1,x2,y,w;}p[MAX];
bool operator<(Node a,Node b){return a.y<b.y;}
double S[MAX];
int top;
int n,tot;
struct SegmentTreeNode
{
double ss;
int ly;
}t[MAX<<3];
void pushup(int now,int l,int r)
{
if(t[now].ly)t[now].ss=S[r+1]-S[l];
else if(l==r)t[now].ss=0;
else t[now].ss=t[lson].ss+t[rson].ss;
}
void Modify(int now,int l,int r,int L,int R,int w)
{
if(L<=l&&r<=R)
{
t[now].ly+=w;
pushup(now,l,r);
return;
}
int mid=(l+r)>>1;
if(L<=mid)Modify(lson,l,mid,L,R,w);
if(R>mid)Modify(rson,mid+1,r,L,R,w);
pushup(now,l,r);
}
int main()
{
int TT=0;
while(scanf("%d",&n))
{
++TT;
if(!n)break;
tot=top=0;
double x1,x2,y1,y2;
for(int i=1;i<=n;++i)
{
scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2);
p[++tot]=(Node){x1,x2,y1,1};
p[++tot]=(Node){x1,x2,y2,-1};
S[++top]=x1,S[++top]=x2;
}
sort(&S[1],&S[top+1]);
sort(&p[1],&p[tot+1]);
top=unique(&S[1],&S[top+1])-S-1;
double ans=0;
for(int i=1;i<tot;++i)
{
int l=lower_bound(&S[1],&S[top+1],p[i].x1)-S;
int r=lower_bound(&S[1],&S[top+1],p[i].x2)-S-1;
if(l<=r)Modify(1,1,top,l,r,p[i].w);
if(i!=tot)ans+=(p[i+1].y-p[i].y)*t[1].ss;
}
printf("Test case #%d\nTotal explored area: %.2f\n\n",TT,ans);
memset(t,0,sizeof(t));
}
return 0;
}

最新文章

  1. visul studio 文件分包
  2. poj 1847 Tram
  3. Unity3D——窗体介绍
  4. SQL点滴7—使用SQL Server的attach功能出现错误及解决方法
  5. Linux下nginx+多个Tomcat负载均衡的实现
  6. ABP官方文档翻译 8.1 通知系统
  7. c/c++ 图相关的函数(二维数组法)
  8. c++11 条件变量 生产者-消费者 并发线程
  9. 使用node.js的开发框架express创建一个web应用
  10. 设置py文件的路径
  11. vba的一个DB操作类
  12. PHP 多进程开发
  13. Phalcon的MVC框架解析
  14. PAT 甲级 1099 Build A Binary Search Tree
  15. ubuntn 内核升级到LINUX v4.11.8:
  16. 关于softnet的加密硬件狗 也就是所谓的赛孚耐
  17. HDU - 5406 CRB and Apple (费用流)
  18. MD5加密+加盐
  19. Java笔记20:迭代器模式
  20. Unity Inspector 给组件自动关联引用(二)

热门文章

  1. alertifyjs
  2. 音乐之声——midi制作原理
  3. 对html语义化的理解
  4. 二叉排序树、平衡二叉树、B树&amp;B+树、红黑树的设计动机、缺陷与应用场景
  5. 知识点干货--讲一讲final、finally、finalize的区别
  6. crack the coding interview
  7. [译]前端JS面试题汇总 Part 1(事件委托/this关键字/原型链/AMD与CommonJS/自执行函数)
  8. Win10 部署 依赖 NET3.5 项目,报错 无法安装 NET3.5 ,该如何解决?
  9. ContentProvider工作过程
  10. windows NLB实现MSSQL读写分离--从数据库集群读负载均衡