Luogu P5490 扫描线
模板题,想象一条线从左边扫到右边,只有在矩阵边界才会产生影响,所以我们离散化缩小数据范围,再用线段树维护扫描线上的情况,得出结果
#include<bits/stdc++.h>
#define ls k<<1
#define rs k<<1|1
#define int long long//注意要开longlong
using namespace std;
const int N=1e6+;
int val[N<<];
struct Seg_Tree{
int l,r,sum,cnt;
}tr[N<<];
inline void build(int k,int l,int r){
tr[k].l=l,tr[k].r=r;
if(l==r)return;
int mid=(l+r)>>;
build(ls,l,mid);
build(rs,mid+,r);
}
inline void pushup(int k){
if(tr[k].cnt) tr[k].sum=val[tr[k].r+]-val[tr[k].l];
else tr[k].sum=tr[ls].sum+tr[rs].sum;//下传标记
}
inline void add(int k,int x,int y,int v){
if(tr[k].l>y||tr[k].r<x)return;
if(x<=tr[k].l&&tr[k].r<=y){
tr[k].cnt+=v;
pushup(k);
return;
}
add(ls,x,y,v);
add(rs,x,y,v);
pushup(k);
}
int n,cnt,tot,book[N<<];
struct node{
int x,yl,yr,flag;
}e[N<<];
bool cmp(node a,node b){return a.x<b.x||(a.x==b.x&&a.flag>b.flag);}
signed main(){
scanf("%lld",&n);
for(int i=,xl,xr,yl,yr;i<=n;i++){
scanf("%lld%lld%lld%lld",&xl,&yl,&xr,&yr);
book[++cnt]=yl;book[++cnt]=yr;
e[++tot].x=xl;e[tot].yl=yl;e[tot].yr=yr;e[tot].flag=;
e[++tot].x=xr;e[tot].yl=yl;e[tot].yr=yr;e[tot].flag=-;//离散化
}
sort(book+,book+cnt+);
int h=unique(book+,book+cnt+)-book-;
for(int i=;i<=tot;i++){
int pos1=lower_bound(book+,book+h+,e[i].yl)-book;
int pos2=lower_bound(book+,book+h+,e[i].yr)-book;
val[pos1]=e[i].yl;val[pos2]=e[i].yr;
e[i].yl=pos1;e[i].yr=pos2;//记录
}
sort(e+,e+tot+,cmp);
build(,,tot);
int ans=;
for(int i=;i<=tot;i++){
add(,e[i].yl,e[i].yr-,e[i].flag);
ans+=tr[].sum*(e[i+].x-e[i].x);//得出答案
}
cout<<ans<<endl;
}
Luogu P5490 扫描线的更多相关文章
- 【Luogu P5490】扫描线
Luogu P5490 作为一道模板题让我卡了一个月…… 对于线段树+离散化新手而言这实在是太难了…… 有关离散化: 可以查看这一篇文章:https://www.jianshu.com/p/93476 ...
- BZOJ 4814 Luogu P3699 [CQOI2017]小Q的草稿 (计算几何、扫描线、set)
题目链接 (BZOJ) http://lydsy.com/JudgeOnline/problem.php?id=4814 (Luogu) https://www.luogu.org/problem/P ...
- luogu P1856 [USACO5.5]矩形周长Picture 扫描线 + 线段树
Code: #include<bits/stdc++.h> #define maxn 200007 #define inf 100005 using namespace std; void ...
- BZOJ 2731 Luogu P3219 [HNOI2012]三角形覆盖问题 (扫描线)
题目链接: (bzoj)https://www.lydsy.com/JudgeOnline/problem.php?id=2731 (luogu)https://www.luogu.org/probl ...
- [P5490] 【模板】扫描线 - 线段树
求 \(n\) 个矩形的面积并 Solution 将矩形转化为 \(y_1\) 位置的 + 修改 和 \(y_2\) 位置的 - 修改.然后按照 \(+y\) 顺序依次处理所有的修改,到达的一个新的位 ...
- [CERC2017]Intrinsic Interval——扫描线+转化思想+线段树
[CERC2017]Intrinsic Interval https://www.luogu.org/blog/ywycasm/solution-p4747# 这种“好的区间”,见得还是比较多的了. ...
- 【学习笔记】线段树—扫描线补充 (IC_QQQ)
[学习笔记]线段树-扫描线补充 (IC_QQQ) (感谢 \(IC\)_\(QQQ\) 大佬授以本内容的著作权.此人超然于世外,仅有 \(Luogu\) 账号 尚可膜拜) [学习笔记]线段树详解(全) ...
- 【Luogu P1502】窗口的星星
Luogu P1502 题意很好理解,就是问给出的矩形套住的最大和. 但是做起来却十分麻烦. --来自疯狂爆10分的愤怒 一个比较高效的思路是--把每一个星星作为左下角向右上方拓展形成一个矩形, 拓展 ...
- luogu P1382 楼房
二次联通门 : luogu P1382 楼房 /* luogu P1382 楼房 线段树 + 扫描线 + 离散化 正解貌似是堆... MMP...二段式线段树各种错误... 离散化一下横坐标 扫描线扫 ...
随机推荐
- php 中文乱码问题
http://www.jb51.net/article/30064.htm 翻了好多帖子,发现不知道是不是自己脸黑, 文件头这边加上header("Content-Type: text/ht ...
- 机器学习-利用pickle加载cifar文件
首先这里有百度云的数据集供大家下载:(官网太慢了) 链接:https://pan.baidu.com/s/1G0MxZIGSK_DyZTcuNbxraQ 提取码:ui51 复制这段内容后打开百度网盘手 ...
- Js中关于内部方法、实例方法、原型方法、静态方法的个人见解。
function foo(name){ this.name=name; // 实例方法 this.GetName=function(){ console.log("my name is &q ...
- 多个module实体类集合打一个jar包并上传至远程库
本章内容主要分享多个module中的实体类集合生成到一个jar包中,并且发布到远程库:这里采用maven-assembly-plugin插件的功能来操作打包,内容不长却贴近实战切值得拥有,主要节点内容 ...
- pycharm编辑器配置(持续更新完善)
谨记:pycharm仅是一款编辑器,不要太依赖 pycharm的提示,不然后期换了编辑器就不行了 python解释器安装.多版本共存等 去python官网下载安装,配置环境变量.多版本共存等问题请参见 ...
- 201803-1跳一跳 CCF (C语言)
问题描述 近来,跳一跳这款小游戏风靡全国,受到不少玩家的喜爱. 简化后的跳一跳规则如下:玩家每次从当前方块跳到下一个方块,如果没有跳到下一个方块上则游戏结束. 如果跳到了方块上,但没有跳到方块的中心则 ...
- 172. 阶乘后的零 Java解法
https://leetcode-cn.com/problems/factorial-trailing-zeroes/ 172. 阶乘后的零 这题要完成其实要知道一个很巧妙的思想,就是阶乘里面,后面的 ...
- 加深对C#数据类型的认识
值类型: 值类型源于System.Value家族,每个值类型的对象都有一个独立的内存区域用于保存自己的值,值类型 所在的内存区域称之为栈(Stack),只要在代码中修改它,就会在内存区域保存这个值. ...
- windows下用easybcd引导ubuntu出现grub的解决方案
linux安装时吧boot挂在到单独的分区 如果grub覆盖了mbr的话可以用pe工具箱修复windows的mbr linux引导项选grub 驱动器选安装时挂载了/boot的分区 添加条目 启动即可 ...
- css3系列之transform 详解rotate
rotate rotateX rotateY rotateZ rotate3d rotate: 旋转该元素,配合着transform-origin属性,transform-origin 是设置旋转点的 ...