版权声明: 本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
title: "题解 - Codeforces Round #640 Div. 4" categories:
菜 我 菜
<!-- more -->把一个不超过 $10^4$ 的数分成个十百千万
直接做就行
输入 $n,k$, 要求将 $n$ 拆分成 $k$ 个奇偶性相同, 且和为 $n$ 的数
按 $n,k$ 的奇偶性讨论有解情况
首先 $k$ 必定小于等于 $n$
其次只有奇数个奇数的和才会是奇数, 所以 $n$ 为奇数时 $k$ 必为奇数
然后因为能拆分出来的偶数最小为 $2$, 所以需要拆分成偶数列时必有 $n\geqslant2k$
另外 $n=k$ 时需要特判一下
输入 $n,k$, 输出第 $k$ 个不能被 $n$ 整除的数
人傻了, 比赛时愣是没推出来
列个表, 绿色代表不被 $n$ 整除的数, 红色代表被 $n$ 整除的数
绿色的数一共 $k$ 个, 所以最后一个绿色数即为所求
当 $k\operatorname{mod}(n-1)>0$ 时
$$ \def\K{\lfloor\frac{k}{n-1}\rfloor} \def\arraystretch{1.5} \begin{array}{c:c:c:c:c|c} \color{green}1 & \color{green}2 & \color{green}... & \color{green}... & \color{green}n-1 & \color{red}n \ \hdashline \color{green}n+1 & \color{green}n+2 & \color{green}... & \color{green}... & \color{green}2n-1 & \color{red}2n \ \hdashline \color{green}\vdots & \color{green}\vdots & \color{green}... & \color{green}... & \color{green}\vdots & \color{red}\vdots \ \hdashline \color{green}\K n+1 & \color{green}\K n+2 & \color{green}... & \color{green}\K n+ k\operatorname{mod}(n-1) & \end{array} $$
此时的答案为 $\lfloor\frac{k}{n-1}\rfloor n+ k\operatorname{mod}(n-1)$
当 $k\operatorname{mod}(n-1)=0$ 时,
$$ \def\K{\lfloor\frac{k}{n-1}\rfloor} \def\arraystretch{1.5} \begin{array}{c:c:c:c|c} \color{green}1 & \color{green}2 & \color{green}... & \color{green}n-1 & \color{red}n \ \hdashline \color{green}n+1 & \color{green}n+2 & \color{green}... & \color{green}2n-1 & \color{red}2n \ \hdashline \color{green}\vdots & \color{green}\vdots & & \color{green}\vdots & \color{red}\vdots \ \hdashline \color{green}(\K-1) n+1 & \color{green}(\K-1) n+2 & \color{green}... & \color{green}\K n-1 & \color{red}\K n \end{array} $$
此时的答案为 $\lfloor\frac{k}{n-1}\rfloor n-1$
有一堆蛋糕排成一列, Alice 和 Bob 站在两端
要求每个回合只有一人吃蛋糕, 且该回合吃掉的蛋糕总数要严格大于上一个回合, 下一个回合再由另一个人吃蛋糕, 蛋糕吃完后结束
Alice 先手吃一块
问总回合数和二人吃掉的蛋糕总数
直接模拟
给出一组数, 要求找出满足 数组中某个数等于该数组一段区间和(长度 $\geqslant2$)的数的个数
万万没想到直接暴力 $O(n^2)$ 就行菜 我 菜
输入三个数n0, n1, n2
, 要求构造一段 01 序列, 满足00
子串一共n0
个, 10
和01
子串一共n1
个, 11
子串一共n2
个
保证n0, n1, n2
至少有一个数非 0
分情况讨论一下就行
感觉我的写法太丑了, 仅供参考哈
找出 $n$ 的一个全排列, 满足相邻两数差的绝对值在 2 和 4 之间
$n<4$ 时显然无解
当 $n\geqslant4$ 为奇数时我们可以这样构造
n n-2 ... 3 1 4 2 6 ... n-3 n-1
当 $n\geqslant4$ 为偶数时我们可以这样构造
n-1 n-3 ... 3 1 4 2 6 ... n-2 n