小球错排问题

问题描述:
有 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])

  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值