比赛链接
http://codeforces.com/gym/102832
A. Krypton
题意
充游戏币,首充可以获得优惠,之后充值就没有优惠了,问你x元最多能拿到多少游戏币。
$$
\begin{array}{|c|c|c|}
\hline
\text{Price (RMB yuan)}
& \text{Normal amount (coupons)}
& \text{First recharge reward (coupons)}
\ \hline 1 & 10 & 8
\ \hline 6 & 60 & 18
\ \hline 28 & 280 & 28
\ \hline 88 & 880 & 58
\ \hline 198 & 1980 & 128
\ \hline 328 & 3280 & 198
\ \hline 648 & 6480 & 388
\ \hline
\end{array}
$$
题解
只考虑首充,这个题目本质上就是一个01背包,考虑其他充值,是一个完全背包。
1 |
|
D. Meaningless Sequence
题意
$$
a_n = \begin{cases} 1, & n = 0 \ c \cdot \max\limits_{0 \leq i < n} a_{n \operatorname{&} i}, & \text{otherwise} \end{cases},
$$
你要计算
$$
\left( \sum\limits_{i=0}^n a_i \right) \bmod (10^9+7)
$$
题解
$a_i$与数字i的二进制表示法中有多少个1有关,如果有k个,则为c的k次方,直接数位dp即可。
http://codeforces.com/gym/102832/submission/115385503
1 |
|
F. Strange Memory
题意
给你一颗点带权的树,你要计算,其中$\oplus$表示异或
$$
\sum\limits_{i=1}^n\sum\limits_{j=i+1}^n [a_i \oplus a_j = a_{\operatorname{lca}(i, j)}] (i \oplus j).
$$
题解
暴力枚举lca,如果解决了一些子树的子问题,那么合并到父节点的时候,只需要枚举不同子树里面有多少个数满足点权异或和等于父节点值。
很明显这里是三个变量,但是当枚举lca时,父节点值为定值,所以实际上只有两个变量,由于异或构成群,于是可以枚举一个变量,寻找另一个变量,很自然想到了枚举小的子树,在大的子树中寻找,这实际上就是树上启发式合并。
http://codeforces.com/gym/102832/submission/115392207
1 |
|
K. Ragdoll
题意
给你一个森林,每个点有一个权,有三个操作,
- 增加一个单个节点的树
- 合并两颗树
- 修改一颗树的某个节点的权
每次操作以后你要输出有多少对节点在同一棵树且$gcd(i,j)=i\oplus j$
题解
预处理出所有$gcd(i,j)=i\oplus j$的数对,然后启发式合并。
- 本文作者: fightinggg
- 本文链接: http://fightinggg.github.io/yilia/yilia/QSOXOA.html
- 版权声明: 本博客所有文章除特别声明外,均采用 MIT 许可协议。转载请注明出处!