「JOI 2014 Final」裁剪线
做法一
首先将边界也视作四条裁剪线,整个平面作为一张纸,视存在 \(y = -\infty, y = +\infty, x = -\infty, x = +\infty\) 四条直线。
按照纵坐标依次扫描每条线,每次维护当前纵坐标水平无穷长的直线和每个位置下面第一条之前插入过的纵坐标之间围成区域的连通性,如下图所示:
图中箭头指向的就是当前扫描(维护)到的(水平)线,红绿蓝分别为所围成的区域(有效)。
具体地,由于上述扫描过程中连通性只会在:水平线段,竖直线段底部,竖直线段顶部发生改变,因此我们将这些位置按照纵坐标排序依次考虑。
同时,为了方便我们直接让每条竖直线段管辖其右边第一个区域和其他区域的连通性。
- 竖直线段底部
将原本一整段区域分成了两段,考虑对新加入的竖直线段新建一个区域,其余左边最近的区域联通,那么在并查集上连边。
- 竖直线段顶部
无论如何,只需要将左右两个区域在并查集上联通即可。
- 水平线段
加入水平线段后,中间被完全覆盖的区域与外界且两两之间不连通,需要赋予全新的并查集编号,这里显然不能暴力,考虑用数据结构维护。
首先对于竖直线段我们要支持插入,删除,查询前驱,平衡树显然可以直接胜任。
水平线段需要整个区域打上重新标号的懒标记,下次再进行横向覆盖的时候,整个区间存在懒标记的节点接下来一定都不会与外界联通需要直接加入答案,因此平衡树上还需要维护区间内懒标记没有被释放的点的数量。
最后我们再统计所有区域在并查集节点中构成的连通块数量加入答案即可。
因为有查询前驱操作,所以可以事先插入 \(x = -\infty\) 这条直线,最后答案需要减一。
注意在下传懒标记的时候只需要新建点而不需要在并查集上连边,时空复杂度均为 \(\mathcal{O}(n \log n)\).
做法二
注意到本题是网格图的一部分,那么一定是一张平面图,考虑利用欧拉公式求平面图面的数量。
注意本题可能不连通,设交点数量为 \(V\),线段 数(不是交点之间的边数!)为 \(E\),面数为 \(F\),线段 联通块(不是交点连通块个数)个数为 \(C\).
之所以和欧拉定理设的不同是因为统计线段连通块数比交点连通块数好做,原本交点间边数和交点连通块个数差可以抵掉一部分变为 \(E, C\) 之间的关系,即:
\]
那么只需要求出 \(V, E, C\) 即可,\(E\) 显然是好求的,\(V\) 是经典扫描线问题,考虑如何求 \(C\).
依然考虑扫描线,沿水平从下往上扫描,每次相当于支持加删竖直线段,将水平线段和一个区间内的竖直线段连边。
考虑线段树优化区间连边,我们把每个竖直线段插入到线段树上对应的 \(\log\) 个区间,每次水平线段找到区间在线段树上 \(\log\) 个子区间。
注意到整个区间内的点如果全部和一个点联通那么这些点都是联通的,我们只需要保留一个代表节点即可。
很显然,代表节点就是顶端纵坐标最大的点,这样可以保证正确性。
复杂度与做法一的复杂度相同但思维难度降低了。
「JOI 2014 Final」裁剪线的更多相关文章
- 【题解】LOJ2759. 「JOI 2014 Final」飞天鼠(最短路)
[题解]LOJ2759. 「JOI 2014 Final」飞天鼠(最短路) 考虑最终答案的构成,一定是由很多飞行+一些上升+一些下降构成. 由于在任何一个点上升或者下降代价是一样的,所以: 对于上升操 ...
- 「JOI 2014 Final」飞天鼠
「JOI 2014 Final」飞天鼠 显然向上爬是没有必要的,除非会下降到地面以下,才提高到刚好为0. 到达一个点有两种情况:到达高度为0和不为0. 对于高度不为0的情况,显然花费的时间越少高度越高 ...
- 【2018.10.1】「JOI 2014 Final」年轮蛋糕
题面 一看到求“最小值的最大值”这种问题,就能想到二分了. 二分答案,然后我们要把一圈分成三块,使这三块的大小都$\geq mid$.做法是把环展开成2倍长度的链,先钦定一个起点,然后根据前缀和再二分 ...
- loj 2759「JOI 2014 Final」飞天鼠
loj 这题有在一棵树上上升或者下降的操作,稍加分析后可以发现上升操作如果不是一定要做(指高度不足以到下一棵树或者是最后到达\(n\))就不做,下降操作也是如果不是一定要做(指到达下一棵树时高度过高) ...
- 「JOI 2017 Final」JOIOI 王国
「JOI 2017 Final」JOIOI 王国 题目描述 题目译自 JOI 2017 Final T3「 JOIOI 王国 / The Kingdom of JOIOI」 JOIOI 王国是一个 H ...
- LOJ#2351. 「JOI 2018 Final」毒蛇越狱
LOJ#2351. 「JOI 2018 Final」毒蛇越狱 https://loj.ac/problem/2351 分析: 首先有\(2^{|?|}\)的暴力非常好做. 观察到\(min(|1|,| ...
- 【LOJ】#3014. 「JOI 2019 Final」独特的城市(长链剖分)
LOJ#3014. 「JOI 2019 Final」独特的城市(长链剖分) 显然我们画一条直径,容易发现被统计的只可能是直径某个距离较远的端点到这个点的路径上的值 用一个栈统计可以被统计的点,然后我们 ...
- 「JOI 2015 Final」城墙
「JOI 2015 Final」城墙 复杂度默认\(m=n\) 暴力 对于点\((i,j)\),记录\(ld[i][j]=min(向下延伸的长度,向右延伸的长度)\),\(rd[i][j]=min(向 ...
- 「JOI 2015 Final」舞会
「JOI 2015 Final」舞会 略微思考一下即可知该过程可以化为一棵树.(3个贵族中选择1个,即新建一个节点连向这3个贵族). 该树的结点个数为\(2n\). 考虑二分答案mid. 判定的是公主 ...
随机推荐
- 【死磕Java并发】-----Java内存模型之重排序
在执行程序时,为了提供性能,处理器和编译器常常会对指令进行重排序,但是不能随意重排序,不是你想怎么排序就怎么排序,它需要满足以下两个条件: 在单线程环境下不能改变程序运行的结果: 存在数据依赖关系的不 ...
- eclipse的安装及最大子数组求和
我安装的是eclipse.由于eclipse是一个基于Java的课扩展开发平台,所以在安装eclipse之前要先安装Java的开发工具JDK(Java Devolopment Dit),且安装JDK需 ...
- matplotlb 进阶之Styling with cycler
目录 cycler 教程 函数链接 matplotlib教程学习笔记 cycler 在教程开始之前,我们需要了解cycler模块 from __future__ import print_functi ...
- 使用 JavaScript自定义函数计算出教室的体积大小,其中教室的长、宽、高分别为 8 米、5 米、3 米
查看本章节 查看作业目录 需求说明: 使用 JavaScript自定义函数计算出教室的体积大小,其中教室的长.宽.高分别为 8 米.5 米.3 米 实现思路: 创建 HTML 页面 在页面的 < ...
- 用软碟通UltraISO刻录Win 10 1909 到U盘,只有1个G左右,安装不了系统
之前一直用软碟通刻录WIN10的ISO镜像到U盘.最近想到用最新版的WIN10 1909 来做一个U盘系统,刻录也成功了.就是安装系统的时候总报错,找了很久原因,终于发现刻录后占用U盘的空间只有1G左 ...
- spring boot 集群 + Nginx --- 心得
1.前言 已经掌握了spring cloud 得使用 ,但这是在内部网络做业务 ,现在需要 在外部网络 访问内部网络 服务 ,引入了 服务端负载均衡 Nginx , Nginx 根据预定的策略 ,将请 ...
- 51 Nod 1183 编辑距离 (动态规划基础)
原题链接:1183 编辑距离 题目分析:这个最少的操作次数,通常被称之为编辑距离."编辑距离"一次本身具有最短的意思在里面.因为题目有"最短"这样的关键词,首先 ...
- virtual stuido同时调试多个控制台
问题 UDP作业需要服务器端和客户端收发信息完成交互,需要同时调试多个窗口. 解决办法 但是缺点依然是无法调试2个,修改另一个测试. 所以多开可能依然是好办法.
- LINUX系统机器人
简介 在2016年,国内的软硬件尚不能有效支撑我们制造智能机器人,我们无法有效在Linux进行语音唤醒,只能使用斯坦福大学狮身人面像语音开源项目来进行英文识别我们对RIMA的呼唤,抗干扰性为0,意味着 ...
- 解决vscode下载很慢的问题
1.打开vscode官网,https://code.visualstudio.com; 2.点击下载稳定版;这里我的电脑是win10版本 3.下载时可以去谷歌的下载内容里面,看到正在下载的vscode ...