loj#P3773. 「APIO2022」排列
「APIO2022」排列
题目描述
在 LibreOJ,本题仅保证使用 GNU C++17 编译将得到预期的编译结果,使用其他编译器版本不保证编译结果一定符合预期。
法老们利用行星的引力来加速飞船。假设飞船将依次以 的轨道速度飞掠 颗行星。飞掠每颗行星时,法老科学家可以选择是否利用它来加速飞船。为了节省能量,当飞船以轨道速度 飞掠一颗行星并完成加速后,它将不能再在以轨道速度 飞掠行星时进行加速。也就是说,选择用来加速的行星构成 的一个递增子序列。 的子序列是从 中删除零个或多个元素得到的序列。例如,、、 和 是 的子序列,但 不是。
科学家已经确认,总共有 种方案来选择行星对飞船进行加速,但是他们弄丢了轨道速度的记录信息(甚至包括 的大小)。不过他们记得 是 的一个排列。这里的排列是包含从 到 每个整数恰好一次的序列。 你的任务是找出一个长度尽量小且符合要求的排列 。
你要对 艘不同的飞船来解决该问题。对每艘飞船 ,你会得到一个整数 ,表示选择行星加速飞船的不同方案数。你的任务是找出长度 足够小的轨道速度序列,使得从中恰好可以选出 个轨道速度递增的行星子序列。
实现细节
请在程序开头引入库 perm.h
。你要实现以下函数:
int[] construct_permutation(int64 k);
- 是应有的递增子序列的数量。
- 该函数要返回有 个元素的数组,每个元素是 到 之间(包括 和 )的数。
- 返回的数组必须是恰好有 个递增子序列的合法排列。
- 该函数总共被调用 次。每次调用被视为一个独立的场景。
2
3
8
2
1 0
3
0 1 2
样例 2
考虑以下调用:
construct_permutation(8);
该函数应该返回一个恰好有 个递增子序列的排列。一种可能的答案是 。
约束条件
- 。
- (对所有 )。
子任务
- ( 分)(对所有 )。如果你给出的所有排列长度至多为 且结果正确,你将获得 分,否则获得 分。
- ( 分)没有额外的约束条件。对该子任务,令 为你在所有场景中给出的排列的最大长度,则你的得分按下表来计算:
条件 | 得分 |
---|---|
数据范围与提示
评测程序示例按以下格式读取输入:
- 第 行:。
- 第 行():。
评测示例程序对每个 打印一行,包含对应 construct_permutation
调用的返回值。如果出错则打印错误信息。