poj-1151-Atlantis-线段树求面积并
非常裸的线段树求面积并。
坐标须要离散化一下。
- #include<stdio.h>
- #include<iostream>
- #include<stdlib.h>
- #include<string.h>
- #include<algorithm>
- #include<vector>
- #include<math.h>
- #include<map>
- #pragma comment(linker, "/STACK:1024000000,1024000000")
- using namespace std;
- #define maxn 11000
- #define mem(a,b) (memset(a),b,sizeof(a))
- #define lmin 1
- #define rmax len
- #define lson l,(l+r)/2,rt<<1
- #define rson (l+r)/2+1,r,rt<<1|1
- #define root lmin,rmax,1
- #define now l,r,rt
- #define int_now int l,int r,int rt
- #define INF 99999999
- #define LL long long
- #define mod 10007
- #define eps 1e-6
- #define zero(x) (fabs(x)<eps?
- 0:x)
- map<double,int>mp;
- double du[4010];
- int len;
- struct list
- {
- double x1,y1;
- double x2,y2;
- }node[maxn];
- struct linen
- {
- double y1,y2;
- int leap;
- double x;
- friend bool operator <(const linen &a,const linen &b)
- {
- if(zero(a.x-b.x)!=0) return a.x<b.x;
- else return a.leap>b.leap;
- }
- }line[maxn*2];
- double num[maxn*4*4*2];
- int cover[maxn*4*4*2];
- void push_up(int_now)
- {
- if(cover[rt]==0)
- {
- num[rt]=num[rt<<1]+num[rt<<1|1];
- }
- if(cover[rt]>=1)
- {
- num[rt]=du[r+1]-du[l];
- }
- // cout<<rt<<" "<<du[l]<<"===="<<du[r+1]<<" "<<cover[rt]<<" "<<num[rt]<<" "<<sum[rt]<<endl;
- }
- void push_down(int_now)
- {
- }
- void creat(int_now)
- {
- memset(cover,0,sizeof(cover));
- memset(num,0,sizeof(num));
- }
- void updata(int ll,int rr,int x,int_now)
- {
- if(ll>r||rr<l)return;
- if(ll<=l&&rr>=r)
- {
- // cout<<l<<" "<<r<<"-"<<du[l]<<" "<<du[r+1]<<" "<<endl;
- cover[rt]+=x;
- push_up(now);
- return;
- }
- updata(ll,rr,x,lson);
- updata(ll,rr,x,rson);
- push_up(now);
- }
- int main()
- {
- int t,n,s;
- int cas=0;
- while(~scanf("%d",&n)&&n)
- {
- cas++;
- s=0;
- for(int i=1;i<=n;i++)
- {
- scanf("%lf%lf%lf%lf",&node[i].x1,&node[i].y1,&node[i].x2,&node[i].y2);
- du[++s]=node[i].x1;
- du[++s]=node[i].y1;
- du[++s]=node[i].x2;
- du[++s]=node[i].y2;
- line[i*2-1].x=node[i].x1;
- line[i*2-1].y1=node[i].y1;
- line[i*2-1].y2=node[i].y2;
- line[i*2-1].leap=1;
- line[i*2].x=node[i].x2;
- line[i*2].y1=node[i].y1;
- line[i*2].y2=node[i].y2;
- line[i*2].leap=-1;
- }
- sort(line+1,line+n*2+1);
- sort(du+1,du+s+1);
- du[0]=-1;
- len =0;
- mp.clear();
- for(int i=1;i<=s;i++)
- {
- if(du[i]!=du[i-1])
- {
- mp[du[i]]=++len;
- du[len]=du[i];
- }
- }
- creat(root);
- double st=0;
- double are=0.0;
- for(int i=1;i<=len;i++)
- {
- // cout<<i<<"----"<<du[i]<<endl;
- }
- len--;
- // cout<<1<<" "<<len<<" "<<1<<" "<<endl;
- for(int i=1;i<=n*2;i++)
- {
- int l,r;
- l=mp[line[i].y1];
- r=mp[line[i].y2];
- if(zero(line[i].x-st)!=0)
- {
- are+=(line[i].x-st)*num[1];
- st=line[i].x;
- }
- // cout<<line[i].x<<" "<<line[i].y1<<" "<<line[i].y2<<" "<<" "<<line[i].leap<<endl;
- updata(l,r-1,line[i].leap,root);
- //cout<<l<<" "<<r<<" "<<are<<endl;
- }
- printf("Test case #%d\n",cas);
- printf("Total explored area: %.2f\n\n",are);
- }
- return 0;
- }
poj-1151-Atlantis-线段树求面积并的更多相关文章
- POJ 1151 Atlantis 线段树求矩形面积并 方法详解
第一次做线段树扫描法的题,网搜各种讲解,发现大多数都讲得太过简洁,不是太容易理解.所以自己打算写一个详细的.看完必会o(∩_∩)o 顾名思义,扫描法就是用一根想象中的线扫过所有矩形,在写代码的过程中, ...
- POJ 1151 - Atlantis 线段树+扫描线..
离散化: 将所有的x轴坐标存在一个数组里..排序.当进入一条线段时..通过二分的方式确定其左右点对应的离散值... 扫描线..可以看成一根平行于x轴的直线..至y=0开始往上扫..直到扫出最后一条平行 ...
- hdu 1542&&poj 1151 Atlantis[线段树+扫描线求矩形面积的并]
Atlantis Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total S ...
- POJ 1151 Atlantis 线段树+离散化+扫描线
这次是求矩形面积并 /* Problem: 1151 User: 96655 Memory: 716K Time: 0MS Language: G++ Result: Accepted */ #inc ...
- POJ 1151 / HDU 1542 Atlantis 线段树求矩形面积并
题意:给出矩形两对角点坐标,求矩形面积并. 解法:线段树+离散化. 每加入一个矩形,将两个y值加入yy数组以待离散化,将左边界cover值置为1,右边界置为2,离散后建立的线段树其实是以y值建的树,线 ...
- HDU 1828 / POJ 1177 Picture --线段树求矩形周长并
题意:给n个矩形,求矩形周长并 解法:跟求矩形面积并差不多,不过线段树节点记录的为: len: 此区间线段长度 cover: 此区间是否被整个覆盖 lmark,rmark: 此区间左右端点是否被覆盖 ...
- hdu-1255(线段树求面积并)模板
题目链接:传送门 思路: (1)建立线段的信息,每个线段存储l到r的线段的x位置和y的起始点与终点. 建立线段树的节点信息,每个节点代表一个区间的信息,x表示区间的横坐标的位置,l,r表示纵坐标的范围 ...
- POJ 1151 扫描线 线段树
题意:给定平面直角坐标系中的N个矩形,求它们的面积并. 题解:建立一个四元组(x,y1,y2,k).(假设y1<y2)用来储存每一条线,将每一条线按x坐标排序.记录所有的y坐标以后排序离散化.离 ...
- HDU - 1255 覆盖的面积 (线段树求面积交)
https://cn.vjudge.net/problem/HDU-1255 题意 给定平面上若干矩形,求出被这些矩形覆盖过至少两次的区域的面积. 分析 求面积并的题:https://www.cnbl ...
- HDU - 1542 Atlantis(线段树求面积并)
https://cn.vjudge.net/problem/HDU-1542 题意 求矩形的面积并 分析 点为浮点数,需要离散化处理. 给定一个矩形的左下角坐标和右上角坐标分别为:(x1,y1).(x ...
随机推荐
- STM32 IIC双机通信—— HAL库硬件IIC版
参考传送门 关于IIC的原理这里我就不多说了,网上有很多很好的解析,如果要看我个人对IIC的理解的话,可以点击查看,这里主要讲一下怎样利用STM32CubeMx实现IIC的通讯,经过个人实践,感觉HA ...
- sql删除注意的问题
老大骂你都是有原因的,基础要打好!!!! SQL关于删除的三个语句:DROP.TRUNCATE. DELETE 的区别. DROP test; 删除表test,并释放空间,将test表删除的一干二净 ...
- oracle 用户解锁和修改用户密码
1.安装教程参看:https://jingyan.baidu.com/article/3c48dd34be2a32e10be35881.html 2.用户解锁 --> 运行cmd --> ...
- nginx配置修改
改变nginx配置想让它生效而不停止服务,如下两种方式都可以:1) 检查nginx配置: nginx -t; 配置重载: nginx -s reload2) 检查nginx配置: nginx -t; ...
- 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 ...
- C#-GC基础(待补充)
Finalize方法与Dispose方法区别 1. Finalize只释放非托管资源: 2. Dispose释放托管和非托管资源: // D 是神的天敌3. 重复调用Finalize和Dispose是 ...
- freemark实现遍历 list,每行三个
我的做法是先做一个模板,这三个只都是从list里取出来的 在后台将每三个值放到一个map里 List<Map<String, Object>> newsList=new Arr ...
- [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 ...
- Android_通过Bugtags平台,方便測试人员提交bug及整个bug系统的管理
Bugtags 是什么? Bugtags 是一款缺陷发现及管理工具. 当您的 App 集成了 Bugtags SDK 后,測试人员就可直接在 App 里所见即所得的提交 Bug. SDK 会自己主动截 ...
- dpdk l2fwd 应用流程分析
int MAIN(int argc, char **argv) { struct lcore_queue_conf *qconf; struct rte_eth_dev_info dev_info; ...