#CF2040C. 有序排列
有序排列
C. 有序排列
每个测试的时间限制:2 秒
内存限制:256 兆字节
考虑一个由 到 的整数构成的排列 * 。我们可以为它定义如下和 †:
[ S(p) = \sum_{1 \le l \le r \le n} \min(p_l, p_{l+1}, \dots, p_r) ]
现在考虑所有长度为 且 达到最大可能值的排列。输出其中字典序 ‡ 第 小的排列,或者若不足 个则报告。
注释
- 一个长度为 的排列是由 个从 到 的互异整数按任意顺序组成的数组。例如, 是一个排列,但 不是( 出现两次), 也不是( 但数组中有 )。
† 例如:
- 排列 的 值等于:
$\min(1) + \min(1,2) + \min(1,2,3) + \min(2) + \min(2,3) + \min(3) = 1+1+1+2+2+3 = 10$ - 排列 的 值等于:
$\min(2) + \min(2,4) + \min(2,4,1) + \min(2,4,1,3) +$
‡ 数组 字典序小于数组 当且仅当以下之一成立:
- 是 的前缀,但 ;
- 在 和 第一个不同的位置上, 的元素小于 的对应元素。
输入
每个测试包含多个测试用例。第一行包含测试用例数 ()。
每个测试用例一行包含两个整数 和 (;)—— 排列的长度和所需排列的序号。
保证所有测试用例的 之和不超过 。
输出
对于每个测试用例,如果符合条件的排列不足 个,输出 。
否则,输出第 个符合条件的排列。
示例
输入:
6
3 2
3 3
4 11
4 6
6 39
7 34
输出:
1 3 2
2 3 1
-1
2 4 3 1
-1
2 3 4 5 7 6 1
注释
我们计算长度为 的所有排列的所需和(按字典序排列):
| 排列 | 值 |
|---|---|
| 10 | |
| 9 | |
| 10 | |
| 9 | |
| 10 |
在第一个测试用例中,需要输出长度为 的第二个符合条件的排列。从上表可知是 。
在第二个测试用例中,需要输出第三个符合条件的排列,即 。