错位排序算法

首先,让我们理解什么是错位排列:

错位排列是指在排列中,任何一个元素都不在自己原来的位置上。比如,对于序列 {1,2,3}{1,2,3},一个错位排列可能是 {3,1,2}{3,1,2},因为 11 不在位置 11 上,22 不在位置 22 上,33 不在位置 33 上。

  1. 基本概念
  • 对于 nn 个元素,每个元素都不能放在原来的位置上
  • 记录 nn 个元素的错排数量为 D(n)D(n)
  1. 简单推导
  • n=1n=1 时:没有错排可能,D(1)=0D(1)=0
  • n=2n=2 时:只有一种错排方式 (1,2)→(2,1)(1,2)→(2,1),D(2)=1D(2)=1
  • n=3n=3 时:有两种错排方式 (1,2,3)→(2,3,1),(3,1,2)(1,2,3)→(2,3,1),(3,1,2) ,D(3)=2D(3)=2

递推公式推导 假设我们要计算nn个元素的错排数量,我们可以这样思考:

  • 先把第 nn 个元素放到某个位置 ii 上( ii 可以是 11 到 n−1n−1 中的任何位置)

  • 对于位置 ii 原来的元素,我们有两种选择:

    • 把 ii 放到位置nn:剩下 n−2n−2 个元素的错排问题

    • 不把 ii 放到位置 nn:剩下 n−1n−1个元素的错排问题

因此得到递推公式: D(n)=(n−1)×D(n−2)+D(n−1)D(n)=(n−1)×D(n−2)+D(n−1)

边界条件: D(1)=0D(1)=0 D(2)=1D(2)=1

递推公式的实际意义

  • (n−1)(n−1):表示第 nn 个元素可以放的位置数量
  • D(n−2)D(n−2):表示把 ii 放到 nn 的位置后,剩余元素的错排数量
  • D(n−1)D(n−1):表示不把 ii 放到 nn 的位置,剩余元素的错排数量

错位排列在实际生活中有很多应用,比如:

  • 帽子问题:n个人参加晚会,他们的帽子被服务员打乱,求没有人能拿到自己帽子的情况数
  • 信件投递问题:n封信装入n个信封,求没有一封信装入正确信封的情况数
相关推荐
猿人谷5 小时前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络6 小时前
Stable Diffusion 视觉大模型微调技术深度调研
算法
复杂网络6 小时前
基于 Stable Diffusion 架构的视觉大模型代表性工作与原理深度解析
算法
MrZhao4006 小时前
Agent Loop 如何用 Hook 扩展:权限、日志与工具拦截
算法
MrZhao4006 小时前
Agent 为什么需要 Skills:别把所有知识都塞进 system prompt
算法
JieE2122 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2123 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack203 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树3 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2124 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法