Pārlūkot izejas kodu

add post/2021-hdu-4

Xi Ruoyao 3 gadi atpakaļ
vecāks
revīzija
44a45596a5
1 mainītis faili ar 68 papildinājumiem un 0 dzēšanām
  1. 68 0
      content/post/2021-hdu-4.md

+ 68 - 0
content/post/2021-hdu-4.md

@@ -0,0 +1,68 @@
++++
+date = "2021-07-29T18:05:00+08:00"
+draft = false
+tags = []
+title = "2021 杭电多校 (“中超联赛”) 第四场"
+authors = ["xry111"]
++++
+
+大概过程:
+
+* 开场读 K,然后发现不可做
+* 然后读了 F,就是个最小树形图,
+但是要求 $10^5$ 点还要输出以每个点为根的答案……
+* 然后读了 I,发现事签到题,就去写,结果因为没初始化变量写出了 `-O0`
+能跑一开优化就错的代码。改了以后又因为少写一个特判 WA 了 $114514$ 发。
+* 然后帮王老师写了 D 的暴力对拍
+* 然后自闭 E 最后没过
+
+# [License Plate Recognition](https://acm.hdu.edu.cn/showproblem.php?pid=6993)
+
+## 题意
+
+给了你一个像素字体,每次输入一个车牌
+(保证是我国标准样式,而且没有噪点啥的),让你输出里面每个字符的 $x$
+坐标范围。
+
+## 做法
+
+把字全拍扁成一维的,然后除了“川”和“鄂”两个字会断开,剩下都不会。
+结果因为没特判“鄂” WA 了 $114514$ 发。
+
+# [Didn't I Say to Make My Abilities Average in the Next Life?!](https://acm.hdu.edu.cn/showproblem.php?pid=6989)
+
+## 题意
+
+给定一个数组 $a$,每次询问 $x$ 和 $y$,求
+$$\sum_{x \leq l \leq r \leq y} \frac{1}{(y-x+2)(y-x+1)}(\max_{l \leq k \leq r} a\_k +
+\min_{l \leq k \leq r} a\_k)$$
+
+## 做法
+
+显然可以拆成最大值和最小值两部分去做,做法是一样的,下面只考虑最大值。
+
+我们考虑 $i$ 位置的这个 $下a\_i$ 事区间内最大值
+(如果有多个相同最大值则必须是第一个) 的情况数,设它左边最近的大于它的位置是
+$l\_i$,右边最近的小于它的位置是 $r\_i$,再假设询问的是开区间 $(x\_j, y\_j)$
+(就给输入都分别加一减一就行了),情况数就是
+
+$$(i - \max(l\_i, x\_j))(\min(r\_i, y\_j) - i)$$
+
+对答案的贡献就是情况数乘以 $a\_i$。然后对 $\max$ 和 $\min$ 做分类讨论处理,
+看上去会得到若干个三维偏序问题:
+
+* $x\_j < i < y\_j$
+* $l\_i \leq x\_j$ 或 $x\_j < l\_i$
+* $r\_i < y\_j$ 或 $y\_j < r\_i$
+
+然后就现学 cdq 去了,自闭了 $114$ 分钟。
+结果到最后一小时突然发现因为 $l\_i < i < r\_i$
+必然成立,可以把第一个条件合并到后两个条件里面去:
+
+* $l\_i \leq x\_j < i$ 或 $x\_j < l\_i$
+* $i < y\_j \leq r\_i$ 或 $r\_i < y\_j$
+
+就剩下两维了 (就像是 2019 年新生赛接水果那个题一样),
+一维排序一维线段树搞一下就行了。然而由于要打 $4$ 个标记
+(分别是区间内应该乘以 $1$, $x\_j$, $y\_j$, $x\_j y\_j$ 的项),
+还得分 $4$ 类讨论 (最后写了 $193$ 行),自闭到最后也没过,赛后才过。