仅仅想说题目给的欲实际不服     还是这类型的水题吧   建议看之前我写的那个

#include<stdio.h>

#include<string.h>

#include<algorithm>

#include<iostream>

using namespace std;

#define LL(x) (x<<1)

#define RR(x) ((x<<1)|1)





int n;

struct node

{

double y;

int x1,x2;

int flash;

}A[31000];

struct Node

{

int ii;

double x;

}change[35000];

int cmp1(Node a,Node b)

{

return a.x<b.x;

}

int cmp2(node a,node b)

{

return a.y<b.y;

}

int num[80000];

double map[31000];

int update(int L,int R,int left,int right,int k,int mark)

{

int mid=(L+R)/2;

if(L==left&&right==R)

{

if(num[mark]!=-1)

{

num[mark]+=k;

return 0;

}

update(L,mid,L,mid,k,LL(mark));

update(mid,R,mid,R,k,RR(mark));

if(num[LL(mark)]==num[RR(mark)]) num[mark]=num[LL(mark)];

else num[mark]=-1;

}

else

{

if(num[mark]>=0)

{

num[LL(mark)]=num[RR(mark)]=num[mark];

}

if(right<=mid)

{

update(L,mid,left,right,k,LL(mark));

}

else if(left>=mid)

{

update(mid,R,left,right,k,RR(mark));

}

else

{

update(L,mid,left,mid,k,LL(mark));

update(mid,R,mid,right,k,RR(mark));

}

if(num[LL(mark)]==num[RR(mark)]) num[mark]=num[LL(mark)];

else num[mark]=-1;

}

return 0;

}

double find(int L,int R,int mark)

{

double Long=0;

if(num[mark]>=1)

{

Long+=map[R]-map[L];

return Long;

}

if(num[mark]==0) return 0;

int mid=(L+R)/2;

Long+=find(L,mid,LL(mark))+find(mid,R,RR(mark));

return Long;


}

int main()

{

int i,j,d=1;

double x1,y1,x2,y2;

while(~scanf("%d",&n),n)

{

n*=2;

//j=0;

memset(A,0,sizeof(A));

memset(map,0,sizeof(map));

memset(change,0,sizeof(change));

for(i=1;i<=n;i+=2)

{

scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2);

A[i].y=y1;

A[i].flash=1;

A[i+1].y=y2;

A[i+1].flash=-1;

change[i].x=x1;

change[i+1].ii=change[i].ii=i;

change[i+1].x=x2;



int leap[10000];

memset(leap,0,sizeof(leap));

sort(change+1,change+1+n,cmp1);

int j=0;

double k=-1;

for(i=1;i<=n;i++)

{

if(change[i].x!=k)

{

k=change[i].x;

++j;

map[j]=change[i].x;

}

if(leap[change[i].ii]==0)

{

A[change[i].ii].x1=A[change[i].ii+1].x1=j;

leap[change[i].ii]=1;

}

else  A[change[i].ii].x2=A[change[i].ii+1].x2=j;

}

sort(A+1,A+1+n,cmp2);

memset(num,0,sizeof(num));

update(1,j,A[1].x1,A[1].x2,1,1);

double area=0;

for(i=2;i<=n;i++)

{    

area+=find(1,j,1)*(A[i].y-A[i-1].y);

if(A[i].flash==1)

update(1,j,A[i].x1,A[i].x2,1,1);

else update(1,j,A[i].x1,A[i].x2,-1,1);

}

printf("Test case #%d\n",d++);

printf("Total explored area: %.2lf\n",area);

printf("\n");

}

return 0;

}

hdu1542 线段树+扫描线+离散化的更多相关文章

  1. hdu1542 Atlantis (线段树+扫描线+离散化)

    Atlantis Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

  2. POJ-1151-Atlantis(线段树+扫描线+离散化)[矩形面积并]

    题意:求矩形面积并 分析:使用线段树+扫描线...因为坐标是浮点数的,因此还需要离散化! 把矩形分成两条边,上边和下边,对横轴建树,然后从下到上扫描上去,用col表示该区间有多少个下边,sum代表该区 ...

  3. hdu1542 线段树扫描线求矩形面积的并

    题意:       给你n个正方形,求出他们的所占面积有多大,重叠的部分只能算一次. 思路:       自己的第一道线段树扫描线题目,至于扫描线,最近会写一个总结,现在就不直接在这里写了,说下我的方 ...

  4. HDU1542 Atlantis —— 求矩形面积并 线段树 + 扫描线 + 离散化

    题目链接:https://vjudge.net/problem/HDU-1542 There are several ancient Greek texts that contain descript ...

  5. poj1151 Atlantis (线段树+扫描线+离散化)

    有点难,扫描线易懂,离散化然后线段树处理有点不太好理解. 因为这里是一个区间,所有在线段树中更新时,必须是一个长度大于1的区间才是有效的,比如[l,l]这是一根线段,而不是区间了. AC代码 #inc ...

  6. hdu 4419 线段树 扫描线 离散化 矩形面积

    //离散化 + 扫描线 + 线段树 //这个线段树跟平常不太一样的地方在于记录了区间两个信息,len[i]表示颜色为i的被覆盖的长度为len[i], num[i]表示颜色i 『完全』覆盖了该区间几层. ...

  7. HDU 1542 Atlantis (线段树 + 扫描线 + 离散化)

    Atlantis Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

  8. HDU 1542 Atlantis(线段树扫描线+离散化求面积的并)

    Atlantis Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

  9. HDU 1255 覆盖的面积 (线段树+扫描线+离散化)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1255 题意很清楚,就是让你求矩阵之间叠加层数大于1的矩形块的面积和. 因为n只有1000,所以我离散化 ...

随机推荐

  1. Android通过透明度设置背景变暗

    变暗 WindowManager.LayoutParams lp=getWindow().getAttributes(); lp.alpha=0.3f; getWindow().addFlags(Wi ...

  2. JDBC链接数据库步骤

    java中定义链接数据库的标准:JDBC 1.导包:不同数据库有不同的jdbc驱动包,而且jdbc驱动包和数据库版本必须对应 2.测试 3.写代码 try { 1.//加载JDBC驱动    Clas ...

  3. JS——拖拽盒子

    注意事项: 1.opacity是全部元素变透明,rgba只是背景色变透明 2.先是注册鼠标按下的事件,此时就需要记录鼠标在盒子中的坐标 3.再在鼠标按下事件中注册鼠标移动事件,此时鼠标的坐标是不断变化 ...

  4. ZipMarket数字内容/素材交易网站源码项目

    ZipMarket程序仿自Envato旗下网站,对于想创建数字内容/素材交易平台的站长来说,ZipMarket是一个十分独特和极具创新的解决方案,用户在你的网站注册并购买或出售数字内容/素材作品时,你 ...

  5. Struts2框架实现简单的用户登入

    Struts框架汲取了Struts的优点,以WebWork为核心,拦截器,可变和可重用的标签. 第一步:加载Struts2 类库: 第二步:配置web.xml <?xml version=&qu ...

  6. Detectron-MaskRCnn: 用于抠图的FCNN

    市面上暂时还没有找到可以在消费机显卡上实时运行的MaskRCnn,TensorFlow即使是C++版本训练在coco数据集上的模型也是慢的要死,最后不堪忍受,只能放弃. 经历了一些列fuckingDo ...

  7. 自己写一个爬虫 copider

    copider 模仿scrapy的一些写法,当然我这个是单进程的,不是异步的 1.目录 copider/copider.py #coding=utf-8 ''' Created on 2015年10月 ...

  8. Jenkins里jobs和workspace什么区别

    https://segmentfault.com/q/1010000012575095/a-1020000012590560 简单的说,job 中保存的是项目是在 jenkins 上的配置.日志.构建 ...

  9. MFC CAD控制权问题

    begineditorcommand(); 隐藏对话框  把控制权交给CAD completeeditorcommand(); 完成交互返回到应用程序 canceleditorcommand CAD被 ...

  10. Unity的分辨率

    问题: 强制设置程序运行的分辨率 解决办法: 在程序开始运行时就对分辨率进行设定 设定方法如下: void GetResolution() { int width = Screen.currentRe ...