c++请教一个简单的递推问题!!!

来源:百度知道 编辑:UC知道 时间:2024/05/29 12:50:46
一个人有n封信,他将n封信装到n个信封里面,全部装错!!
推出一个排错公式:f(n)=(n-1)*((n-2)+(n-1))!!!
好像是这个!!!我想问一下,就这个提来讨论!!他究竟怎样来的???
还有n封信放到n个信封内,一共有多少种方法??是否是n的阶成??
最后,在弱弱的问一下,哪位大哥大姐能否给我找点递推中阶成方面的资料!!
希望高手解答一下!!!我不要代码,只要分析过程!!!
十分谢谢!!!
。。。。。我正学者离散数学呢!!!貌似这是个很简单的问题,高三就已经学过。。。。

你的公式错了,应该是
f(n)=(n-1) {f(n-1)+f(n-2)}
思路如下:
用A、B、C……表示n个信封,a、b、c……表示n份信。把错装的总数为记作f(n)。假设把a错装进B里了,包含着这个错误的一切错装法分两类:
(1)b装入A里,这时每种错装的其余部分都与A、B、a、b无关,应有f(n-2)种错装法。
(2)b装入A、B之外的一个信封,这时的装信工作实际是把(除a之外的)n-1份信纸b、c……装入(除B以外的)n-1个信封A、C…….因为这种情况要和(1)区分开来,所以b不能放到A,这时可以把b看成一个a',题目就成了把a',c,....放入A,C.....,要全放错,所以这时装错的方法有f(n-1)种。
总之在a装入B的错误之下,共有错装法f(n-2)+f(n-1)种。a装入C,装入D……的n-2种错误之下,同样都有f(n-2)+f(n-1)种错装法,因此:
f(n)=(n-1) {f(n-1)+f(n-2)}

其实,这个问题已经有通项公式了,百度出来的推导如下:
n个相异的元素排成一排a1,a2,...,an,且ai(i=1,2,...,n)不在第i位的排列数为n!(1-1/1!+1/2!-1/3!+...+(-1)^n*1/n!)
证明:
设1,2,...,n的全排列t1,t2,...,tn的集合为I,而使ti=i的全排列的集合记为Ai(1<=i<=n),
则Dn=|I|-|A1∪A2∪...∪An|.
所以Dn=n!-|A1∪A2∪...∪An|.
注意到|Ai|=(n-1)!,|Ai∩Aj|=(n-2)!,...,|A1∩A2∩...∩Am|=0!=1.
由容斥原理:
|A1∪A2∪...∪An|=n(n-1)!-C(n,2)(n-2)!+C(n,3)(n-3)!-...+(-1)^(n-1)C(n,n)*0!
=n!(1/1!-1/2!+...+(-1)^(n-1)*1/n!),
所以
Dn=n!(1-1/1!+1/2!-1/3!+...+(-1)^n