1359. 有效的快递序列数目
题目描述
给你 n
笔订单,每笔订单都需要快递服务。
计算所有有效的 取货 / 交付 可能的顺序,使 delivery(i) 总是在 pickup(i) 之后。
由于答案可能很大,请返回答案对 10^9 + 7 取余的结果。
示例 1:
输入:n = 1 输出:1 解释:只有一种序列 (P1, D1),物品 1 的配送服务(D1)在物品 1 的收件服务(P1)后。
示例 2:
输入:n = 2 输出:6 解释:所有可能的序列包括: (P1,P2,D1,D2),(P1,P2,D2,D1),(P1,D1,P2,D2),(P2,P1,D1,D2),(P2,P1,D2,D1) 和 (P2,D2,P1,D1)。 (P1,D2,P2,D1) 是一个无效的序列,因为物品 2 的收件服务(P2)不应在物品 2 的配送服务(D2)之后。
示例 3:
输入:n = 3 输出:90
提示:
1 <= n <= 500
解法
方法一:动态规划
我们定义 \(f[i]\) 表示 \(i\) 个订单的所有有效的收件/配送序列的数目。初始时 \(f[1] = 1\)。
我们可以选择这 \(i\) 个订单中的任意一个作为最后一个配送的订单 \(D_i\),那么它的收件订单 \(P_i\) 可以在之前 \(2 \times i - 1\) 的任意一个位置,剩下的 \(i - 1\) 个订单的配送/收件序列数目为 \(f[i - 1]\),所以 \(f[i]\) 可以表示为:
\[
f[i] = i \times (2 \times i - 1) \times f[i - 1]
\]
最终的答案即为 \(f[n]\)。
我们注意到 \(f[i]\) 的值只与 \(f[i - 1]\) 有关,所以可以用一个变量代替数组,降低空间复杂度。
时间复杂度 \(O(n)\),其中 \(n\) 为订单数目。空间复杂度 \(O(1)\)。
1 2 3 4 5 6 7 |
|
1 2 3 4 5 6 7 8 9 10 |
|
1 2 3 4 5 6 7 8 9 10 11 |
|
1 2 3 4 5 6 7 8 |
|
1 2 3 4 5 6 7 8 9 10 11 12 |
|