错位排序算法

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

错位排列是指在排列中,任何一个元素都不在自己原来的位置上。比如,对于序列 {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 小时前
profiler debug 工具用法与高一致性策略
算法·自动驾驶
编程大师哥5 小时前
匿名函数 lambda + 高阶函数
java·python·算法
isyangli_blog5 小时前
OpenDayLight (Carbon 版本) 启动与组件安装
开发语言·php
vb2008116 小时前
FastAPI APIRouter
开发语言·python
Benszen6 小时前
KVM虚拟化解决方案
开发语言·perl
会编程的土豆6 小时前
Go 语言反射(Reflection)详解
开发语言·后端·golang
東雪木6 小时前
多线程与并发编程 专属复习笔记
java·开发语言·笔记·java面试
我叫袁小陌6 小时前
算法解题思路指南
算法
地平线开发者6 小时前
Conv+BN+Add+ReLU 融合机制简介
算法·自动驾驶
也曾看到过繁星6 小时前
数据结构---顺序表
数据结构