|
思路: 求出每个数据包在网络中存在的最(晚)后时刻,不妨记作 $last$,则 $last>T$ 的数据包数即是答案。 要点: 1、对于被复制的某数据包,服务器 $i$ 只会转发最早且第一次到达自己的那个复制包,因为后续到达的相同数据包将会被接收而不再转发; 2、最早到达服务器 $i$ 的复制包一定是通过最短路(最少传输时间)抵达的,然后通过服务器 $i$ 的最长出边转发出去的复制包可能会在网络中存在更久; 3、那么,对于服务器 $i$ 而言,某数据包传输过程分为两段:(1)从起点 $s$ 沿最短路抵达服务器 $i$;(2)沿服务器 $i$ 最长边转发至邻接服务器; 则:某数据包传输时间 $=$ $shortest[i]$ $+$ $farest[i]$,前者是从 $s \sim i$ 的最短路,后者是 $i$ 的最长出边;
综上,$last = max\{ shortest[i] + farest[i] \} + startime$(开始传输时刻)
题目282 [NOI 1998]SERNET模拟
AAAAA
![]()
2022-09-22 00:19:08
|
|
这一题的一个比较简单的思路,就是对于一个点 $a_i$,找到 $y$ 坐标在区间 $[y_i + m, max_y]$ 内的所有点中,$x_i$ 的前驱和后继,然后更新答案。 对于二维平面上的的区间查询问题,树套树应该是最经典的解法了。比如这一题可以用线段树套平衡树,对于线段树的每个节点 $[L, R]$ 上建立一个平衡树,保存输入序列上 $y$坐标 落在 $[L, R]$ 内的点的 $x$ 坐标。因为平衡树本身支持查询前驱和后继,所以实现树套树之后就很简单了,该算法的时间复杂度为 $O(n \log^2 n)$。不过似乎树套树主要用来解决带修的这种问题,并且不容易调试,码长略长,所以还是思考另外的做法。
跟磁力块那一题的解法类似,可以用分块做,一开始觉得用分块时间复杂度可能比较高(当时还准备放弃写树套树,幸亏我太蒻了没学过树套树,要不然掉进坑里了),但是实际好像相当快? 对于每个块用 $y$ 值排序,内部用 $x$ 值排序,对于每一个点,二分找到满足条件(即 $y$ 坐标和该点的 $y$ 坐标的差 $\ge m$)的最小的块(预先保存每个块的最小 $y$ 值),由于预先排序保证了这个块之后的块也都满足条件,然后再在这些块内部二分找到 $x$ 坐标的前驱和后继,更新答案,然后对于最左的块的左边一个块,朴素枚举,更新答案。 对于每一个点的查询操作,时间复杂度为 $O(\sqrt n \log n)$ 故总时间复杂度为 $O(n \sqrt n \log n)$
当然,这样的时间复杂度还是很高,但是还有很多优秀的算法:
譬如 skylake 大佬的算法:通过维护 $y$ 坐标的区间最值,然后用尺取法,保证两个最值的差 $\ge m$,然后更新答案。这个算法实在是太优秀了,并且代码写出来极为简洁,好像是大佬开始比赛十分钟秒掉的?简直叹为观止 orzorz%%%%%%%%,我还没有学过 RMQ,可能不是很了解,不过据推测这个时间复杂度是 $O(n \log n + n)$?果然犇人写犇算法,直接比我的算法快一个数量级(虽然可能这一题数据太水,我的代码反而快了 再譬如 关神犇 提出的算法:维护两个二叉堆,堆内以 $y$ 坐标为关键字,并且在堆外以 $x$ 为关键字排序。每次枚举一个点就取出两个堆中满足条件的点,更新答案,然后弹出这些数(因为已经以 $x$ 为关键字排序,所以在当前点之后的点不会离这些点更近,即这些点对于答案已经没有贡献了),之后把该点存入堆内。这个算法实在是太神了(关神犇您是我的神orzorzorz%%%%%%%%%%%%%%%),因为只进行了 $2n$ 次插入和 $n$ 次删除操作,每个操作的时间复杂度是 $\log n$,所以总时间复杂度为 $O(n \log n)$。看这道题的标签里有优先队列,也许正解就是这个,为此再次膜拜神犇叹为观止的做题直觉orzorz。 当然,除此之外,还有用线段树维护区间最值的神犇的方法,具体思路和 skylake 大佬的大同小异,不过线段树实现代码更加冗长,这里不再赘述。 上述各位神犇的思路我都进行了代码实现,可以去 我的博客 察看作为参考。
题目3741 双倍腹肌量
![]()
2022-09-16 23:38:30
|
|
选择了第一个选左边或者右边之后,不难想到第一个选到的数所对应的另一个数一定要最后一个输出,为了达到最后一个输出,这个两边的数要分开处理,左边的数对应的都是 L,右边的数对应的都是 R。 将这两边看做两个队列 $L$ 和 $R$,首先我们感性地考虑:两边队头对应的另一个数一定比较 “远”,猜测可能是两边队列的队尾。接下来我们证明一定是队尾: 假设接下来要确定的回文子串的长度是 $l$(先前确定在答案序列中的数已在队列中删除),那么 $|L| + |R| - 2 = l - 2$,就是说除了这两个数之外的 $l - 2$ 个数都要先弹出队列,如果对应的这个数不在队尾,那么除非包括这个数弹出,弹出队列的数量达不到 $l - 2$,就是说这个数把队列卡住了。由此,队头对应的数一定是队尾,如果两个队列的队尾都没有对应的数,就说明无解。 确定队头对应的数一定是其中一个队列的队尾之后,把这个两个数从队列中删除也就不难了,只需实现两个双端队列,弹出一个队头之后把这个队尾也弹出就行了,假设队头的答案序列位置是 $k$,那么对应的队尾的位置就是 $n - k + 1$。 考虑字典序,我们优先把第一个数选为 L,并且队头也要优先考虑 L 。
题目3621 [CSP 2021S]回文
AAAAAAAAAAAAAAAAAAAAAAAAA
![]()
2022-09-16 23:34:26
|
|
题面由wzw改编自NOIP1998 提高组 进制位
前置结论:1.进制为n-1 2.单个字母对应的数字即为所在行两位数个数 3.单个字母对应的数字即为其在表中(除表头)出现的次数-1 证明:1.因为n-1个不同的数,所以最少n-1进制。假设为n进制,那么一定有一个数没有出现,设为k (1)k=0或1,1+(n-1)=10,不成立 (2)1<k≤n-1,1+(k-1)=k,不成立 同理可证大于n-1进制的情况不成立,故进制一定为n-1。 2.字母对应的数字为0…n-2,易证结论2。 3.设字母对应的数字为x,则x=0+x=1+(x-1)=2+(x-2)=... =(x-1)+1=x+0
方法
|
|
因为这篇题解原文是用 Markdown 写成,在 我的博客 上面可能会有更好的阅读体验
考虑一个合法的括号序列长什么样子:
根据定义,一个合法的括号序列,内部可以是: $$A_{i, j} = A_{i + 1, j - 1} + S_{i + 1, j - 1} + AS_{i + 1, j - 1} + SA_{i + 1, j - 1} \notag$$ 接下来,我们考虑这些部分的信息如何维护:
对于 $$AS_{i, j} = \sum_{i \le k \le j}A_{i, k} \times S_{k + 1, j} \notag \\ SA_{i, j} = \sum_{i \le k \le j}S_{i, k} \times A_{k + 1, j} \notag \\ ASA_{i, j} = \sum_{i \le k \le j}A_{i, k} \times SA_{k + 1, j} \notag \\ AA_{i, j} = \sum_{i \le k \le j}A_{i, k} \times A_{k + 1, j} \notag \\$$
需要注意的是,如果我们将
题目3620 [CSP 2021S]括号序列
AAAAAAAAAAAAAAAAAAAA
![]()
2022-08-28 15:15:55
|
|
$ \begin{aligned}ans &= \frac{\binom{num_l}{2} + \binom{num_{l + 1}}{2} + \dots + \binom{num_r}{2}}{\binom{r - l + 1}{2}} \\ &= \frac{num_l(num_l - 1) + num_{l + 1}(num_{l + 1} - 1) + \dots + num_r(num_r - 1)}{(r - l + 1)(r - l)} \\ &= \frac{(num_l^2 + num_{l + 1}^2 + \dots + num_r^2) - (num_l + num_{l + 1} + \dots + num_r)}{(r - l + 1)(r - l)} \\ &= \frac{(num_l^2 + num_{l + 1}^2 + \dots + num_r^2) - (r - l + 1)}{(r - l + 1)(r - l)} \end{aligned} $ 而 $ (n + 1)^2 = n^2 + 1 + 2n \\ (n - 1)^2 = n^2 + 1 - 2n $ 所以对于每一个询问 $[l, r]$,我们只需要将当前询问的分子加上 $2n + 1$ 即可 $O(1)$ 地将答案扩展至 $[l, r + 1]$ 或 $[l - 1, r]$,而对于缩小区间的操作,同理。 于是,我们可以用 $\mid l' - l \mid + \mid r' - r \mid$ 次操作转移至下一询问区间。 而利用分块,将所处分块作为第一关键字,将右区间作为第二关键字,可以实现 $O(n \sqrt n)$ 的时间复杂度。
题目1775 [国家集训队 2010] 小Z的袜子
AAAAAAAAAAAAAAAAAAAA
![]()
2022-08-24 16:25:10
|