C - Lamps
题意
给定一个长度为n的序列
a
i
{a_i}
ai,定义该
{
a
i
}
\{a_i\}
{ai}序列对应的
{
b
i
}
\{b_i\}
{bi}序列:
b
i
=
∑
j
=
1
n
[
j
−
a
j
≤
i
≤
j
+
a
j
]
b_i=\sum\limits_{j=1}^n[j-a_j\leq i \leq j+a_j]
bi=j=1∑n[j−aj≤i≤j+aj](中括号内的值为真则为1否则为0)
现执行
k
k
k次操作,每次操作求出
{
b
i
}
\{b_i\}
{bi}序列然后替换掉
{
a
i
}
\{a_i\}
{ai}序列,求
k
k
k次操作后的
{
a
i
}
\{a_i\}
{ai}序列。
思路
不超过大概 log n \log n logn次操作后, { a i } \{a_i\} {ai}序列中每个数都变成n,直接模拟即可,当 { a i } \{a_i\} {ai}序列中每个数都变成n时可结束操作。
D - Knapsack Queries on a tree
题意
给定一颗节点数为 n n n的二叉树, 1 1 1为根节点,对于任意节点 i ( i ≥ 2 ) i(i \geq 2) i(i≥2)其父节点为 ⌊ i 2 ⌋ \lfloor \frac{i}{2} \rfloor ⌊2i⌋,每个节点有权值 v i v_i vi和重量 w i w_i wi。现有 q q q次查询,第i次查询格式为 v i v_i vi, l i l_i li,表示在节点 v i v_i vi到根节点这一条链上的节点中,在重量总和不超过 l i l_i li的条件下,求权值之和的最大值。
思路
前
n
\sqrt n
n个节点用dp求出背包数组,查询这些节点时
O
(
1
)
O(1)
O(1)解答;
其他节点:
设树的深度为
d
d
d,对于每个查询,深度大于
d
2
\frac{d}{2}
2d的节点暴搜选或不选,深度小于
d
2
\frac{d}{2}
2d利用之前求得的背包数组,两部分之和求最大值。
E - O(rand)
题意
给出一个序列 { a i } \{a_i\} {ai},求该序列满足以下条件的子集数:
- 该子集所有数的 a n d and and运算结果为 s s s。
- 该子集所有数的 o r or or运算结果为 t t t。
- 子集大小不超过 k k k。
思路
将数二进制下每一位分开考虑。显然 a n d and and运算结果和 o r or or运算结果分别为 0 0 0和 1 1 1的情况无解。分两种情况考虑:
- 两种运算结果均为 0 0 0或均为 1 1 1,所选的数对应位必须为 0 0 0或 1 1 1。
- 两种运算结果分别为 0 0 0和 1 1 1,那么所选的数至少有一个数对应位为 0 0 0,至少有一个数对应位为 1 1 1。考虑容斥,定义“子集 s s s的 i i i位不合法”:子集 s s s中所有数的第 i i i位均为 0 0 0或均为 1 1 1。那么总方案数为满足条件3.的子集数减去满足条件3.并且满足存在某位i不合法的子集数,容斥即可,满足条件3.的方案数可以用组合数来计算。