hdu3265一种错误的做法

题目链接

这是求面积并的题目,刚开始我的思路是将挖去的矩形的入边和出边覆盖效果颠倒,

即入边-1,出边+1,后来调试到爆炸,发现这是错误的做法。。原因就是对最简单

的面积并问题没有搞清楚。刚开始接触扫描线的时候我就有一个问题,为什么覆盖

次数不需要向子区间传递,但是我没有仔细去想这个问题,直到遇到这道题目。在

求相交矩形面积并的过程中,所有的线段都是成对出现,重点在于所有线段的覆盖

都是整段整段的操作,所以不需要向下传。而这道题目用这种做法就会出现一个区

间被较小的区间释放的情况,所以会出错。

#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn=310;//最多矩形个数
struct edge{int x1,x2,y;int f;//1表示入,-1表示出
    edge(){}edge(int _x1,int _x2,int _y,int _f){x1=_x1,x2=_x2,y=_y,f=_f;}bool operator <(edge &e){if(y!=e.y)return y<e.y;return f>e.f;}
};
int nVx;
int Vx[maxn*4];
int nSgs;
edge Sgs[maxn*4];
int num[maxn*4*4];
int len[maxn*4*4];
void build(int root,int l,int r)
{num[root]=len[root]=0;if(l==r)return;int mid=(l+r)/2;build(root*2,l,mid);build(root*2+1,mid+1,r);
}
void pushUp(int root,int l,int r)
{if(num[root]!=0)len[root]=Vx[r+1]-Vx[l];else if(l==r)len[root]=0;else len[root]=len[root*2]+len[root*2+1];printf("%d %d num[%d]=%d\n",l,r,root,num[root]);
}
void update(int root,int L,int R,int f,int l,int r)
{//printf("%d %d %d %d %d %d\n",root,L,R,f,l,r);if(L<=l&&r<=R){num[root]+=f;pushUp(root,l,r);return ;}int mid=(l+r)/2;if(L<=mid)update(root*2,L,R,f,l,mid);if(mid<R)update(root*2+1,L,R,f,mid+1,r);pushUp(root,l,r);
}
int bin(int k)
{int l=0,r=nVx-1,mid;while(l<=r){mid=(l+r)/2;if(Vx[mid]==k)return mid;else if(Vx[mid]>k)r=mid-1;else l=mid+1;}return -1;
}
int myUnique(int a[],int n)
{int sz=1;for(int i=1;i<n;i++){if(a[i]!=a[i-1])a[sz++]=a[i];}return sz;
}
int main()
{freopen("in.txt","r",stdin);int N;while(scanf("%d",&N)!=EOF&&N!=0){nVx=0;nSgs=0;for(int i=0;i<N;i++){int x1,y1,x2,y2,x3,y3,x4,y4;scanf("%d%d%d%d%d%d%d%d",&x1,&y1,&x2,&y2,&x3,&y3,&x4,&y4);printf("%d %d %d %d %d %d %d %d\n",x1,y1,x2,y2,x3,y3,x4,y4);Vx[nVx++]=x1,Vx[nVx++]=x2,Vx[nVx++]=x3,Vx[nVx++]=x4;Sgs[nSgs++]=edge(x1,x2,y1,1);Sgs[nSgs++]=edge(x1,x2,y2,-1);Sgs[nSgs++]=edge(x3,x4,y3,-1);Sgs[nSgs++]=edge(x3,x4,y4,1);}sort(Vx,Vx+nVx);nVx=myUnique(Vx,nVx);sort(Sgs,Sgs+nSgs);build(1,0,nVx-1);int area=0;for(int i=0;i<nSgs-1;i++){int l=bin(Sgs[i].x1);int r=bin(Sgs[i].x2)-1;update(1,l,r,Sgs[i].f,0,nVx-1);printf("%d %d\n",len[1],Sgs[i+1].y-Sgs[i].y);area+=len[1]*(Sgs[i+1].y-Sgs[i].y);}printf("%d\n",area);}while(1);
}
View Code

 先贴一下思路:海报一张可以切割成4个矩形,然后就是普通的矩形面积并了,利

用线段树维护即可

正确做法

#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn=50310;//最多矩形个数
struct edge{int x1,x2,y;int f;//1表示入,-1表示出
    edge(){}edge(int _x1,int _x2,int _y,int _f){x1=_x1,x2=_x2,y=_y,f=_f;}bool operator <(edge &e){if(y!=e.y)return y<e.y;return f>e.f;}
};
int nSgs;
edge Sgs[maxn*8];
int num[maxn*8];
int len[maxn*8];
void build(int root,int l,int r)
{num[root]=len[root]=0;if(l==r)return;int mid=(l+r)/2;build(root*2,l,mid);build(root*2+1,mid+1,r);
}
void pushUp(int root,int l,int r)
{if(num[root]!=0)len[root]=r-l+1;else if(l==r)len[root]=0;else len[root]=len[root*2]+len[root*2+1];//printf("%d %d num[%d]=%d\n",l,r,root,num[root]);
}
void update(int root,int L,int R,int f,int l,int r)
{//printf("%d %d %d %d %d %d\n",root,L,R,f,l,r);if(L<=l&&r<=R){num[root]+=f;pushUp(root,l,r);return ;}int mid=(l+r)/2;if(L<=mid)update(root*2,L,R,f,l,mid);if(mid<R)update(root*2+1,L,R,f,mid+1,r);pushUp(root,l,r);
}
int main()
{//freopen("in.txt","r",stdin);int N;while(scanf("%d",&N)!=EOF&&N!=0){nSgs=0;int lb=0,rb=maxn;for(int i=0;i<N;i++){int x1,y1,x2,y2,x3,y3,x4,y4;scanf("%d%d%d%d%d%d%d%d",&x1,&y1,&x2,&y2,&x3,&y3,&x4,&y4);Sgs[nSgs++]=edge(x1,x2,y1,1);Sgs[nSgs++]=edge(x1,x2,y3,-1);Sgs[nSgs++]=edge(x1,x3,y3,1);Sgs[nSgs++]=edge(x1,x3,y4,-1);Sgs[nSgs++]=edge(x4,x2,y3,1);Sgs[nSgs++]=edge(x4,x2,y4,-1);Sgs[nSgs++]=edge(x1,x2,y4,1);Sgs[nSgs++]=edge(x1,x2,y2,-1);lb=min(x1,lb);rb=max(x2,rb);}sort(Sgs,Sgs+nSgs);build(1,lb,rb);long long  area=0;for(int i=0;i<nSgs-1;i++){int l=Sgs[i].x1;int r=Sgs[i].x2-1;if(l<=r)update(1,l,r,Sgs[i].f,lb,rb-1);//printf("%d %d\n",len[1],Sgs[i+1].y-Sgs[i].y);area+=(long long)len[1]*(Sgs[i+1].y-Sgs[i].y);}printf("%lld\n",area);}//while(1);
}
View Code

参考资料

http://www.cnblogs.com/--ZHIYUAN/p/6404732.html

转载于:https://www.cnblogs.com/MalcolmMeng/p/8456040.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/571174.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php截断上传,截断在文件包含和上传中的利用

截断大概可以在以下情况适用include(require)file_get_contentsfile_exists所有url中参数可以用%00控制0x01. 本地文件包含1.1 截断类型&#xff1a;php %00截断截断条件&#xff1a;php版本小于5.3.4 详情关注CVE-2006-7243php的magic_quotes_gpc为OFF状态漏洞文件lfi.php要in…

解决虚拟机安装64位系统“此主机支持 Intel VT-x,但 Intel VT-x 处于禁用状态”的问题...

环境说明&#xff1a;系统&#xff1a;Windows 8.1 简体中文专业版 虚拟机&#xff1a;VMware Workstation 11.0.0 报错&#xff1a;此主机支持 Intel VT-x&#xff0c;但 Intel VT-x 处于禁用状态。如图&#xff1a; 图片原文如下&#xff1a; 已将该…

#前端# 解决前端页面滑动不顺畅的问题

看情况有时候需要将body和html同时选择。转载于:https://www.cnblogs.com/tnt-33/p/8464370.html

php守护进程热更新,如何通过PHPStorm配置Hyperf热更新开发环境

通过 PHPStorm 配置热更新开发环境在开发 Hyperf/Swoole 这样的持久化应用时&#xff0c;每当应用代码发生了变更时&#xff0c;都需要重启应用使代码生效&#xff0c;尽管在开发 CLI 应用时这也是一个正确且合理地操作&#xff0c;因为我们开发过程中仍需要关注 stdout 输出的…

php elements,wd elements se和wd elements的区别是什么

区别&#xff1a;1、WD Elements SE有两个USB3.0接口&#xff1b;而WD Elements有一个USB3.0接口&#xff0c;一个USB2.0接口。2、WD Elements SE配置有数据加密功能&#xff1b;而WD Elements不具备存储数据加密功能。本文操作环境&#xff1a;windows10系统、thinkpad t480电…

【热修复】Andfix源码分析

转载请标注来源&#xff1a;http://www.cnblogs.com/charles04/p/8471301.html Andfix源码分析 0、目录 背景介绍源码分析方案评价总结与思考参考文献1、背景介绍 热修复技术是移动端领域近年非常活跃的一项新技术&#xff0c;通过热修复技术可以在不发布应用市场版本&#xff…

已知矩阵 matlab,在MATLAB中,已知矩阵A,那么A(:,2:end)表示

摘要&#xff1a;已知供输工方、表示添资料准加剂、加及标应提原料有关的()的出国法等使用&#xff0c;品”“进办理报检时口食。已知信息系统模型不包逻辑括(。...已知信息系统构化中的结方法设计&#xff0c;矩阵细设和详总体计两阶段一般分为设计&#xff0c;总体主要建立其…

文件源码读取 php伪协议,include(文件包含漏洞,php伪协议)

点击tips查看元素&#xff0c;也并没有有用的信息&#xff0c;联想到题目,include想起了文件包含漏洞。构造payload?file/../../../../../../flag.php没有返回东西。看完wq学到了一个新姿势&#xff1a;php伪代码构造payload?filephp://filter/readconvert.base64-encode/res…

Echarts自定义折线图例,增加选中功能

用Echarts图表开发&#xff0c;原本的Echarts图例不一定能满足我们的视觉要求。 下面是Echarts 折线图自定义图例&#xff0c;图例checked选中&#xff0c;相应的折线线条会随之checked&#xff0c;其余未选中的图例对应的折线opacity会降低&#xff0c;&#xff08;柱状图&…

php产品效果图,jQuery_基于JQuery制作的产品广告效果,效果图.如下: 动画效果介绍 - phpStudy...

基于JQuery制作的产品广告效果效果图.如下&#xff1a;动画效果介绍&#xff1a;这组广告效果是打开页面后图片会自动播放&#xff0c;从1-5共计5张图片&#xff0c;如果属标放到右下角的1、2、3、4、5列表上&#xff0c;可以自由进行切换到自己想看的图片上去。图片切换是由下…

Python on the Way, Day1 - Python基础1

一、 Python介绍 python的创始人为吉多范罗苏姆&#xff08;Guido van Rossum&#xff09;。1989年的圣诞节期间&#xff0c;吉多范罗苏姆为了在阿姆斯特丹打发时间&#xff0c;决心开发一个新的脚本解释程序&#xff0c;作为ABC语言的一种继承 Python可以应用于众多领域&#…

python数据显示为什么只能显示最后一个变量,Python变量和简单数据类型,之,的

变量介绍。变量就是代表某个数据(值)的名称&#xff0c;简单点说变量就是给数据起个名字。变量的特点。1)变量是计算机内存中的一块区域&#xff0c;变量可以存储规定范围内的值&#xff0c;而且值是可变的。2)在创建变量时会在内存中开辟一个空间。基于变量的数据类型&#xf…

【BZOJ2095】【POI2010】Bridge 网络流

题目大意 ​  给你一个无向图&#xff0c;每条边的两个方向的边权可能不同。要求找出一条欧拉回路使得路径上的边权的最大值最小。无解输出"NIE"。   \(2\leq n\leq 1000,1\leq m\leq 2000\) 题解 ​  我们先二分答案\(ans\)&#xff0c;把边权大于\(ans\)的边…

space index.php 7-14,SpacePack高效部署PHP生产环境

SpacePack 基于 Docker 为了快速部署 PHP 生产环境而产生的项目&#xff0c;它包含了一般项目中常用的组件&#xff0c;能够在最短的时间内产生一个完善并且优化过的 PHP 生产环境。容器版本SpacePack 默认包含了 OpenResty 1.13、PHP 7.2、MariaDB 10.3、Memcached 1.5、Redis…

云播自带解析php,使用PHP SDK,web端的华为云视频点播接入,加密视频播放的坑与解决方案-全代码篇...

下载phpdemo算是跑起来了&#xff0c;现在就要考虑租户系统如自身验证token的问题了。1、先介绍下我的代码目录2、文件执行的时序图和流程图2、代码demotest.phpfunction curl_request($url,$post,$cookie, $returnCookie0){$curl curl_init();curl_setopt($curl, CURLOPT_URL…

php获取h5视频直链,一种H5播放实时视频的方法与系统与流程

本发明涉及播放实时视频&#xff0c;尤其涉及一种h5播放实时视频的方法与系统。背景技术&#xff1a;h5是指第5代html&#xff0c;也指用h5语言制作的一切数字产品。所谓html是“超文本标记语言”的英文缩写。“超文本”是指页面内可以包含图片、链接&#xff0c;甚至音乐、程序…

基础题

1&#xff0c;别名&#xff0c;内部&#xff0c;外部&#xff0c;hash优先级&#xff1f; 2&#xff0c;screen协助 1.一台screen -S 协助名称 2.另外一台screen -ls 列出目前开的协助会话&#xff08;session&#xff09;&#xff0c;找到上面协助名称对应的session号。 3. sc…

大数据笔记(十三)——常见的NoSQL数据库之HBase数据库(A)

一.HBase的表结构和体系结构 1.HBase的表结构 把所有的数据存到一张表中。通过牺牲表空间&#xff0c;换取良好的性能。 HBase的列以列族的形式存在。每一个列族包括若干列 2.HBase的体系结构 主从结构&#xff1a; 主节点&#xff1a;HBase 从节点&#xff1a;RegionServer 包…

linux内核网络钩子函数使用,Linux内核IOCTL网络控制框架实现实例分析

4.6、inet_ioctl函数由于inet_ioctl函数内容分支很多,但功能、处理不难理解,所以我把一些不常见的内容都省去,挑简单重要的说,完全在于抛砖引玉:static int inet_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg){…switch(cmd){case FIOSETOWN://设置属主cas…

(转)递归转非递归的思路和例子

转自&#xff1a;http://blog.51cto.com/cnn237111/1241956 某些算法逻辑&#xff0c;用递归很好表述&#xff0c;程序也很好写。理论上所有的递归都是可以转换成非递归的。如果有些场合要求不得使用递归&#xff0c;那就只好改成非递归了。 通常改成非递归算法的思路&#xff…