问题描述:
有 n 个小球和盒子,分别编号为 1, 2, · · · , n。现在将这 n 个小球放到 n 个盒子中,请计算每个 盒子有且仅有一个小球,且小球编号和盒子编号不同的方案数 d(n);(n > 0)
- 小球错排问题
- 状态:
dp[i]
表示将 i 个小球放到 i 个盒子中的方案数。 - 状态转移方程:
dp[i] = (i-1)(dp[i-1]+dp[i-2])
- 边界条件:
dp[1]=0,dp[2]=1
物理意义:
假设当前有 n 个小球,对于任意一个小球 k 有 n-1
种放法,它可以放到其他任意小球的位置。此时又可以分为两种操作:
- 把小球 k 放到小球 j 的箱子里,然后把小球 j 放到 k 的箱子里这样的话可以看成除了这两个小球之外,其他 n-2 个小球进行错排,问题就成了
dp[n-2]
- 把小球 k 放到小球 j 的箱子里,但是规定小球 j 不能放在 k 的箱子里,那就是小球 k 已经确定放在 j 箱子中,其他 n-1 个小球要进行错位排序,这个问题就变成了
dp[n-1]
所以状态转移方程就是 dp[i] = (i-1)(dp[i-1]+dp[i-2])