首页 > 其他分享 >题解 CF983D Arkady and Rectangles

题解 CF983D Arkady and Rectangles

时间:2024-02-27 20:44:59浏览次数:29  
标签:Arkady 颜色 log 题解 mn max 区间 Rectangles mx

\(\texttt{link}\)

题意

平面直角坐标系上给定 \(n\) 个矩形,第 \(i\) 个矩形颜色为 \(i\),颜色大的矩形将覆盖颜色小的矩形,问最后能看到几种颜色。

\(1\le n\le 10^5,|x_i|,|y_i|\le 10^9\)

题解

首先离散化,考虑扫描线如何维护序列上的颜色。

一个区间 \([l,r]\) 投射到线段树上 \(O(\log n)\) 个不交区间,总共 \(O(n\log n)\) 个。对于每个区间,直接把每种颜色塞到一个 set 里,当前区间可能被看到的颜色只会是 set 最大值,记为 \(v_x\)。

考虑只插入怎么做,发现 \(i\) 处的颜色即线段树上根节点到 \([i,i]\) 路径上每个 \(v_x\) 取 \(\max\),那我在一个被颜色 \(c\) 完全覆盖的区间 \([l,r]\) 上,若根到 \([l,r]\) 路径上的 \(\max v_x\) 小于 \(c\),且存在该节点到某一叶节点的路径 \(\max v_x\) 也小于 \(c\),说明 \(c\) 可被看到,于是在线段树上维护 \(mn_x\) 表示所有 \(x\) 到叶节点的路径 \(\max v_x\) 的最小值,即可 \(O(1)\) 判断,每次最多增加 \(1\) 个新颜色。

现在加入删除操作,一个区间的删除可能会增加更多可被看到的颜色,但答案最多 \(O(n)\) 个,那我设法只考虑没被看过的颜色,用 \(mx_x\) 表示以 \(x\) 为根的子树,没被统计过且可能会被看见的最大颜色,从 \([l,r]\) 中删掉颜色 \(c\),重新计算 \(v_x\)。pushup 时先继承左右儿子,考虑 \(v_x\) 对 \(mn_x\) 和 \(mx_x\) 的贡献,分两种情况:

  • 若 \(v_x\) 已被统计过,\(mn_x\gets\max(mn_x,v_x)\)。

  • 若 \(v_x\) 未被统计过,\(mx_x\gets\max(mx_x,v_x)\)。

若 \(mn_x>mx_x\),即当前区间可能会被看见的最大颜色比 \([l,r]\) 中已被看见的最小颜色还小,越往上走 \(mn_x\) 只增不减,自然看不见 \(mx_x\) 了,令 \(mx_x\gets 0\)。

若 \(mx_1\ne 0\),说明出现了一种从未被看见的颜色被看到了,标记为已看见,并把 \(mx_1\) 对应的 \(O(\log n)\) 个区间拉出来修改信息。若修改后 \(mx_1\) 仍不为 \(0\),就继续修改,直到 \(mx_1=0\)。因为最多只有 \(n\) 个颜色,所以总修改次数最多 \(n\) 次。

线段树一个 \(\log\),set 一个 \(\log\),时间复杂度 \(O(n\log^2 n)\)。

标签:Arkady,颜色,log,题解,mn,max,区间,Rectangles,mx
From: https://www.cnblogs.com/Terac/p/18038209

相关文章

  • AT_arc117_c [ARC117C] Tricolor Pyramid 题解
    [ARC117C]TricolorPyramid博客阅读体验(也许)更佳题意给一个金字塔的底部颜色组成和生长规律,问顶部的颜色是什么。分析试几次就可以很容易得到的一种构造:令颜色B为\(0\),W为\(1\),R为\(2\)。设左右两个方块的颜色分别为\(col_l\)和\(col_r\),则生长规则可以描......
  • P5605 小 A 与两位神仙 题解
    推销博客P5605小A与两位神仙题意给定\(x\)、\(y\)和\(m\),其中\(m=p^n,n\in\mathbb{N+},p\ge3\),问同余方程\(x^a\equivy\pmodm\)是否有非负整数解。分析前置芝士Pollard_rho原根化简对这种指数型的同余方程是很难解决的,我们要先把它转化成线性的同余方......
  • [ARC121B] RGB Matching 题解
    题意有\(2N\)个物品,每个物品有可爱度\(a_i\)和颜色\(c_i\),将其两两配对。假设物体\(i\)和\(j\)配对,则\(c_i\neqc_j\),则会增加\(|a_i-a_j|\)的不满意度,求最小的不满意度。分析这道题可以贪心解决。我们尽量让每一对物品颜色相同,令每种颜色的总个数为\(cnt_c\),......
  • AT_abc270_g [ABC270G] Sequence in mod P 题解
    [ABC270G]SequenceinmodP博客阅读可能体验更佳题意给出递推式如下,求最小的使\(X_i=G\)成立的\(i\)。\[X_i=\begin{cases}S&i=0\\(A\timesX_{i-1}+B)\bmodp&i\ge1\end{cases}\]分析这里分几种情况来分析:当\(A=0\)时,\(X_i\)要么等于\(S\),要么等于\(B\),直......
  • CF1928C Physical Education Lesson 题解
    洛谷传送门原题传送门题意一种上下波动的数组,给出所在的位置\(n\)和对应的数字\(x\),求出有几种数组满足条件。令\(k\)为最大值,则数组长成这样子:\[1,2,3,\cdots,k-1,k,k-1,k-2,\cdots,2,1,2,3,\cdots\]如图,每\(2(k-1)\)就循环一次。分析因为每\(2(k-1)\)......
  • CF1477A Nezzar and Board 题解
    题意给出数列\(S=\{a_i\}\)和整数\(k\),求是否能通过下面的操作使得\(k\inS\)?操作:选取\(x,y\inS\),将\(2x-y\)加入\(S\)中。分析观察操作可以发现,\(2x-y\)实际上就是数轴上\(y\)关于\(x\)的对称点,因此这个操作只与\(x\)和\(y\)在数轴上的相对位置有关,与......
  • [ABC342D] Square Pair 题解
    洛谷传送门原题传送门题意给出一个数列\(A\),求出满足\(A_iA_j\)为完全平方数的无序数对\((i,j)\)的个数。分析容易想到(但是我在昨晚没想到,可以原地AFO了),对于每个数,如果是\(0\)的话可以直接统计答案(记录\(0\)的个数\(cnt\),最后\(ans\leftarrowans+cnt(n-cnt)+\f......
  • [ABC342E] Last Train 题解
    洛谷传送门原题传送门题意给出一些由\((l,d,k,c,A,B)\)描述的列车,表示每当时间为\(l,l+d,l+2d,\cdots,l+(k-1)d\)时有一半列车从\(A\)出发,经过\(c\)的时间到达\(B\)。问如果从站点\(i,i\in(0,n)\)出发要去站点\(n\),最晚什么时候到达站点\(i\)可以去到站点\(n\)......
  • [ABC342C] Many Replacement 题解
    洛谷传送门原题传送门题意给出由小写字母初始字符串,每次操作将字符串中所有为\(c\)的字符改为\(d\)。输出最终的字符串。分析很明显只需要开一个\(fa\)数组,其中\(fa[i]=j\)表示字母\(i\)被改为了\(j\)。对于每次操作只需要遍历\(26\)个字母,将\(fa[i]=c\)的那些......
  • [ABC341E] Alternating String 题解
    题目传送门原题传送门题意给出长为\(n\)的01串,如果一个子串01交替出现,则称其为“好的”。有\(q\)次询问,把\([x,y]\)中的每一位反转或者询问\([x,y]\)是否是“好的”。分析一眼线段树。用线段树维护区间是否是“好的”,每个节点维护最左段和最右端的值,pushup和q......