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,一经查实,立即删除!

相关文章

java综合案例_综合实例 - Java House - BlogJava

packagebedeck;publicclassBedeckDome {/** 实例变量* *///类中不能实例化对象publicStringstr1;//无初始值&#xff0c;可以被任何类访问protectedStringstr2;//无初始化值&#xff0c;可以被同一包中的所有类访问&#xff0c;可以被所有子类访问privateStringstr3;//无初始化…

53-C++ CH08 01

http://lx.lanqiao.cn/problem.page?gpidT407 算法训练 C CH08 01 时间限制&#xff1a;1.0s 内存限制&#xff1a;256.0MB问题描述已知一个有理数类Zrf_Ratio&#xff0c;实现如下的操作符重载形式&#xff1a;friend std::ostream& operator<<(std::ostream&am…

Linux文件系统选择

自己想做的&#xff0c;刘爱贵在2010年就做完了(⊙ω⊙) http://blog.csdn.net/liuaigui/article/details/5521024 通过综合使用多种标准文件系统Benchmarks对Ext3, Ext4, Reiserfs, XFS, JFS, Reiser4的性能测试对比&#xff0c;对不同应用选择合适的文件系统给出以下方案&…

java里shake是什么意思_shake是什么意思_shake在线翻译_英语_读音_用法_例句_海词词典...

使振作起来 shock sb into activityshake sth ⇔ upShake up the salad-dressing before you put it on.加色拉调料之前先把它摇匀。shake sth ⇔ upMother ran round the room shaking up all the cushions when the door-bell rang.母亲正在屋里跑来跑去忙着抖松所有的坐垫,这…

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; 已将该…

php checkbox 保存,PHP中在数据库中保存Checkbox数据

PHP中在数据库中保存Checkbox数据/* if we passed in an array of the checkboxes we wantto be displayed as checked */foreach ($arr as $ele) {$str . "< td >< input type"checkbox" name"$name" value"$ele- >id"";…

使用exp导出导入,需要注意的问题。

问题&#xff1a;由于段延迟分配。导致新创建的表未分配段。与参数deferred_segment_creation有关。如果是空表&#xff0c;使用exp和imp会导致导不出来表结构。 使用exp加参数rowsn导出元数据&#xff0c;记录一个问题导入后&#xff0c;往表里插入数据&#xff0c;发现占用了…

php 修改excel内容吗,php更新修改excel中的内容例子

//模板存放目录$dir $DOCUMENT_ROOT./backoffice/admin/oemcheck/;$templateName 1.xlsx;$outputFileName 模板.xlsx;$txttest;//实例化Excel读取类$PHPReader new PHPExcel_Reader_Excel2007();if(!$PHPReader->canRead($dir.$templateName)){$PHPReader new PHPExcel…

INNODB表快速迁移

本实验在一台server上启动了2个mysql实例端口分别是3307 3308&#xff0c;目的是将3307的表aaa迁移到3308中去&#xff0c;并打开3308的slave 1.在3308上 mysql> drop table aaa; 干表Query OK, 0 rows affected (0.01 sec)mysql> CREATE TABLE aaa ( -> id …

php递归实现冒泡排序,PHP冒泡排序、快速排序算法

快速排序是对冒泡排序的一种改进。他的基本思想是&#xff1a;通过一趟排序将待排记录分割成独立的两部分&#xff0c;其中一部分的关键字均比另一部分记录的关键字小&#xff0c;则可分别对这两部分记录继续进行快速排序&#xff0c;整个排序过程可以递归进行&#xff0c;以达…

ss加密php,js前端加密,php后端解密(crypto-js,openssl_decrypt)

基于PHP和JS的AES相互加密解密方法详解(CryptoJS)基于PHP和JS的AES相互加密解密方法详解(CryptoJS)注意说明&#xff1a;1. 首先引入CryptoJS包中的aes.js和pad-zeropadding.js2. 其次引入了jquery.min.js和自己封装的function.js(内容主要是加密解密函数)3. 加密解密过程中的向…

MongoDB缓存技术总结

MongoDB简介 MongoDB 是一个基于分布式文件存储的数据库。由C语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。 MongoDB是一个基于分布式文件存储的数据库MongoDB是介于NoSQL和关系型数据库之间的一款产品MongdoDB是基于C语言编写MongoDB具有查询语言、索引、Key-…

java作业 温度换算,Java基础题目(温度转换、时间换算、信号报告)

Java基础题目题目主要来自浙江大学翁凯教授的零基础学习Java课程的配套习题。1. 温度转换题目内容:写一个将华氏温度转换成摄氏温度的程序&#xff0c;转换的公式是&#xff1a;F (9/5)*C 32其中C表示摄氏温度&#xff0c;F表示华氏温度。程序的输入是一个整数&#xff0c;表…

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

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

php写入不了伪静态,PHP实现URL伪静态

核心部分是.htaccess文件&#xff0c;默认可能不支持.htaccess&#xff0c;请查看《apache 不支持.htaccess文件如何处理》。首先我们看下一个地址&#xff1a;http://www.quou.cn/cnweb/0/445/article/这个地址的cnweb其实是虚拟的:为什么没有cnweb这个目录而虚拟主机又认它呢…

头条太给力了!粉丝破千,收益到账925元,总结涨粉经验

越来越喜欢头条了!粉丝破千,开通了千粉权益,收益到账524元。好开心。 昨天粉丝数达到了1000,好激动,赶紧留下纪念,虽然日收益还不是很高,好在又上了一个新台阶。此刻,我也静下心好好总结了一下从0粉丝到1000粉丝的涨粉经验。 1,有效阅读,多互动,增加自己在头条的活…

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

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

Yii2 使用 RESTful 写API接口 实例

Yii2 使用 RESTful&#xff1f;其实 Yii2 框架本身就对 RESTful 是友好支持的&#xff0c;具体可以看官方文档(http://www.yiichina.com/doc/guide/2.0/rest-quick-start)&#xff0c;或者去看源码&#xff0c;都是可以的注意: 我们使用resTful的同时,需要借助于测试工具进行地…

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电…