给你两个整数 n 和 k,一个 交替排列 是前 n 个正整数的排列,且任意相邻 两个 元素不都为奇数或都为偶数。
返回第 k 个 交替排列 ,并按 字典序 排序。如果有效的 交替排列 少于 k 个,则返回一个空列表。
示例 1
输入:n = 4, k = 6
输出:[3,4,1,2]
解释:
[1, 2, 3, 4] 的交替排列按字典序排序后为:
[1, 2, 3, 4][1, 4, 3, 2][2, 1, 4, 3][2, 3, 4, 1][3, 2, 1, 4][3, 4, 1, 2] ← 第 6 个排列[4, 1, 2, 3][4, 3, 2, 1]由于 k = 6,我们返回 [3, 4, 1, 2]。
示例 2
输入:n = 3, k = 2
输出:[3,2,1]
解释:
[1, 2, 3] 的交替排列按字典序排序后为:
[1, 2, 3][3, 2, 1] ← 第 2 个排列由于 k = 2,我们返回 [3, 2, 1]。
示例 3
输入:n = 2, k = 3
输出:[]
解释:
[1, 2] 的交替排列按字典序排序后为:
[1, 2][2, 1]只有 2 个交替排列,但 k = 3 超出了范围。因此,我们返回一个空列表 []。
提示:
1 <= n <= 1001 <= k <= 1015