本文主要是介绍[笔记] 错排问题 #错排,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
参考:刷题笔记-错排问题总结
错排问题:
一个n个元素的排列,若一个排列中所有的元素都不在自己原来的位置上,那么这样的一个排列就称为原排列的一个错排。而研究一个排列的错排个数的问题,就称为错排问题(或称为更列问题)。
错排公式:
D[1]=0;
D[2]=1;
D[n]=(n-1)(D[n-1]+D[n-2])
推导:
对于第i
个元素,若不在自己的位置上,则有n - 1
种情况,取其中一种进行分析:
不充设定:取x -- y
为第x
个元素分到了第y
个元素的位置上
- 若
i -- k
且k -- i
(互换位置),那么将这两个组合剔除,
剩下的n - 2
个元素将继续进行错位排序,共D[n - 2]
种方案。- 若
i -- k
,但k !- i
,那么我们将i -- k
这个组合剔除,
剩下的这n - 1
个元素继续进行错位排序,共D[n - 1]
种方案。
(将第k
个位置与i
重新进行配对。因为每个元素不能放在自己对应的位置上,这个组合刚好又满足这个条件)
这篇关于[笔记] 错排问题 #错排的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!