非常裸的线段树求面积并。

坐标须要离散化一下。

  1. #include<stdio.h>
  2. #include<iostream>
  3. #include<stdlib.h>
  4. #include<string.h>
  5. #include<algorithm>
  6. #include<vector>
  7. #include<math.h>
  8. #include<map>
  9. #pragma comment(linker, "/STACK:1024000000,1024000000")
  10. using namespace std;
  11. #define maxn 11000
  12. #define mem(a,b) (memset(a),b,sizeof(a))
  13. #define lmin 1
  14. #define rmax len
  15. #define lson l,(l+r)/2,rt<<1
  16. #define rson (l+r)/2+1,r,rt<<1|1
  17. #define root lmin,rmax,1
  18. #define now l,r,rt
  19. #define int_now int l,int r,int rt
  20. #define INF 99999999
  21. #define LL long long
  22. #define mod 10007
  23. #define eps 1e-6
  24. #define zero(x) (fabs(x)<eps?
  25.  
  26. 0:x)
  27. map<double,int>mp;
  28. double du[4010];
  29. int len;
  30. struct list
  31. {
  32. double x1,y1;
  33. double x2,y2;
  34. }node[maxn];
  35. struct linen
  36. {
  37. double y1,y2;
  38. int leap;
  39. double x;
  40. friend bool operator <(const linen &a,const linen &b)
  41. {
  42. if(zero(a.x-b.x)!=0) return a.x<b.x;
  43. else return a.leap>b.leap;
  44. }
  45. }line[maxn*2];
  46. double num[maxn*4*4*2];
  47. int cover[maxn*4*4*2];
  48. void push_up(int_now)
  49. {
  50. if(cover[rt]==0)
  51. {
  52. num[rt]=num[rt<<1]+num[rt<<1|1];
  53. }
  54. if(cover[rt]>=1)
  55. {
  56. num[rt]=du[r+1]-du[l];
  57. }
  58. // cout<<rt<<" "<<du[l]<<"===="<<du[r+1]<<" "<<cover[rt]<<" "<<num[rt]<<" "<<sum[rt]<<endl;
  59. }
  60. void push_down(int_now)
  61. {
  62.  
  63. }
  64. void creat(int_now)
  65. {
  66. memset(cover,0,sizeof(cover));
  67. memset(num,0,sizeof(num));
  68. }
  69. void updata(int ll,int rr,int x,int_now)
  70. {
  71. if(ll>r||rr<l)return;
  72. if(ll<=l&&rr>=r)
  73. {
  74. // cout<<l<<" "<<r<<"-"<<du[l]<<" "<<du[r+1]<<" "<<endl;
  75. cover[rt]+=x;
  76. push_up(now);
  77. return;
  78. }
  79. updata(ll,rr,x,lson);
  80. updata(ll,rr,x,rson);
  81. push_up(now);
  82. }
  83. int main()
  84. {
  85. int t,n,s;
  86. int cas=0;
  87. while(~scanf("%d",&n)&&n)
  88. {
  89. cas++;
  90. s=0;
  91. for(int i=1;i<=n;i++)
  92. {
  93. scanf("%lf%lf%lf%lf",&node[i].x1,&node[i].y1,&node[i].x2,&node[i].y2);
  94. du[++s]=node[i].x1;
  95. du[++s]=node[i].y1;
  96. du[++s]=node[i].x2;
  97. du[++s]=node[i].y2;
  98. line[i*2-1].x=node[i].x1;
  99. line[i*2-1].y1=node[i].y1;
  100. line[i*2-1].y2=node[i].y2;
  101. line[i*2-1].leap=1;
  102. line[i*2].x=node[i].x2;
  103. line[i*2].y1=node[i].y1;
  104. line[i*2].y2=node[i].y2;
  105. line[i*2].leap=-1;
  106. }
  107. sort(line+1,line+n*2+1);
  108. sort(du+1,du+s+1);
  109. du[0]=-1;
  110. len =0;
  111. mp.clear();
  112. for(int i=1;i<=s;i++)
  113. {
  114. if(du[i]!=du[i-1])
  115. {
  116. mp[du[i]]=++len;
  117. du[len]=du[i];
  118. }
  119. }
  120. creat(root);
  121. double st=0;
  122. double are=0.0;
  123. for(int i=1;i<=len;i++)
  124. {
  125. // cout<<i<<"----"<<du[i]<<endl;
  126. }
  127. len--;
  128. // cout<<1<<" "<<len<<" "<<1<<" "<<endl;
  129. for(int i=1;i<=n*2;i++)
  130. {
  131. int l,r;
  132. l=mp[line[i].y1];
  133. r=mp[line[i].y2];
  134. if(zero(line[i].x-st)!=0)
  135. {
  136. are+=(line[i].x-st)*num[1];
  137. st=line[i].x;
  138. }
  139. // cout<<line[i].x<<" "<<line[i].y1<<" "<<line[i].y2<<" "<<" "<<line[i].leap<<endl;
  140. updata(l,r-1,line[i].leap,root);
  141. //cout<<l<<" "<<r<<" "<<are<<endl;
  142. }
  143. printf("Test case #%d\n",cas);
  144. printf("Total explored area: %.2f\n\n",are);
  145. }
  146. return 0;
  147. }

poj-1151-Atlantis-线段树求面积并的更多相关文章

  1. POJ 1151 Atlantis 线段树求矩形面积并 方法详解

    第一次做线段树扫描法的题,网搜各种讲解,发现大多数都讲得太过简洁,不是太容易理解.所以自己打算写一个详细的.看完必会o(∩_∩)o 顾名思义,扫描法就是用一根想象中的线扫过所有矩形,在写代码的过程中, ...

  2. POJ 1151 - Atlantis 线段树+扫描线..

    离散化: 将所有的x轴坐标存在一个数组里..排序.当进入一条线段时..通过二分的方式确定其左右点对应的离散值... 扫描线..可以看成一根平行于x轴的直线..至y=0开始往上扫..直到扫出最后一条平行 ...

  3. hdu 1542&&poj 1151 Atlantis[线段树+扫描线求矩形面积的并]

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

  4. POJ 1151 Atlantis 线段树+离散化+扫描线

    这次是求矩形面积并 /* Problem: 1151 User: 96655 Memory: 716K Time: 0MS Language: G++ Result: Accepted */ #inc ...

  5. POJ 1151 / HDU 1542 Atlantis 线段树求矩形面积并

    题意:给出矩形两对角点坐标,求矩形面积并. 解法:线段树+离散化. 每加入一个矩形,将两个y值加入yy数组以待离散化,将左边界cover值置为1,右边界置为2,离散后建立的线段树其实是以y值建的树,线 ...

  6. HDU 1828 / POJ 1177 Picture --线段树求矩形周长并

    题意:给n个矩形,求矩形周长并 解法:跟求矩形面积并差不多,不过线段树节点记录的为: len: 此区间线段长度 cover: 此区间是否被整个覆盖 lmark,rmark: 此区间左右端点是否被覆盖 ...

  7. hdu-1255(线段树求面积并)模板

    题目链接:传送门 思路: (1)建立线段的信息,每个线段存储l到r的线段的x位置和y的起始点与终点. 建立线段树的节点信息,每个节点代表一个区间的信息,x表示区间的横坐标的位置,l,r表示纵坐标的范围 ...

  8. POJ 1151 扫描线 线段树

    题意:给定平面直角坐标系中的N个矩形,求它们的面积并. 题解:建立一个四元组(x,y1,y2,k).(假设y1<y2)用来储存每一条线,将每一条线按x坐标排序.记录所有的y坐标以后排序离散化.离 ...

  9. HDU - 1255 覆盖的面积 (线段树求面积交)

    https://cn.vjudge.net/problem/HDU-1255 题意 给定平面上若干矩形,求出被这些矩形覆盖过至少两次的区域的面积. 分析 求面积并的题:https://www.cnbl ...

  10. HDU - 1542 Atlantis(线段树求面积并)

    https://cn.vjudge.net/problem/HDU-1542 题意 求矩形的面积并 分析 点为浮点数,需要离散化处理. 给定一个矩形的左下角坐标和右上角坐标分别为:(x1,y1).(x ...

随机推荐

  1. STM32 IIC双机通信—— HAL库硬件IIC版

    参考传送门 关于IIC的原理这里我就不多说了,网上有很多很好的解析,如果要看我个人对IIC的理解的话,可以点击查看,这里主要讲一下怎样利用STM32CubeMx实现IIC的通讯,经过个人实践,感觉HA ...

  2. sql删除注意的问题

    老大骂你都是有原因的,基础要打好!!!! SQL关于删除的三个语句:DROP.TRUNCATE. DELETE 的区别. DROP test; 删除表test,并释放空间,将test表删除的一干二净 ...

  3. oracle 用户解锁和修改用户密码

    1.安装教程参看:https://jingyan.baidu.com/article/3c48dd34be2a32e10be35881.html 2.用户解锁 --> 运行cmd --> ...

  4. nginx配置修改

    改变nginx配置想让它生效而不停止服务,如下两种方式都可以:1) 检查nginx配置: nginx -t; 配置重载: nginx -s reload2) 检查nginx配置: nginx -t; ...

  5. 2015 Multi-University Training Contest 7 hdu 5372 Segment Game

    Segment Game Time Limit: 3000/1500 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Tota ...

  6. C#-GC基础(待补充)

    Finalize方法与Dispose方法区别 1. Finalize只释放非托管资源: 2. Dispose释放托管和非托管资源: // D 是神的天敌3. 重复调用Finalize和Dispose是 ...

  7. freemark实现遍历 list,每行三个

    我的做法是先做一个模板,这三个只都是从list里取出来的 在后台将每三个值放到一个map里 List<Map<String, Object>> newsList=new Arr ...

  8. [Python + Unit Testing] Write Your First Python Unit Test with pytest

    In this lesson you will create a new project with a virtual environment and write your first unit te ...

  9. Android_通过Bugtags平台,方便測试人员提交bug及整个bug系统的管理

    Bugtags 是什么? Bugtags 是一款缺陷发现及管理工具. 当您的 App 集成了 Bugtags SDK 后,測试人员就可直接在 App 里所见即所得的提交 Bug. SDK 会自己主动截 ...

  10. dpdk l2fwd 应用流程分析

    int MAIN(int argc, char **argv) { struct lcore_queue_conf *qconf; struct rte_eth_dev_info dev_info; ...