全错位排列
来源:互联网 发布:通过ip查mac地址命令 编辑:程序博客网 时间:2024/04/26 19:45
全错位排列:即被著名数学家欧拉(Leonhard Euler,1707-1783)称为组合数论的一个妙题的“装错信封问题”。
“装错信封问题”是由当时最有名的数学家约翰·伯努利(Johann Bernoulli,1667-1748)的儿子丹尼尔·伯努利(DanidBernoulli,1700-1782)提出来的,大意如下:
一个人写了n封不同的信及相应的n个不同的信封,他把这n封信都装错了信封,问都装错信封的装法有多少种?
递推公式
瑞士数学家欧拉按一般情况给出了一个递推公式:
用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……,显然这时装错的方法有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)}
(摘自百度)
例题:
神、上帝以及老天爷
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Problem Description
HDU 2006'10 ACM contest的颁奖晚会隆重开始了!
为了活跃气氛,组织者举行了一个别开生面、奖品丰厚的抽奖活动,这个活动的具体要求是这样的:
首先,所有参加晚会的人员都将一张写有自己名字的字条放入抽奖箱中;
然后,待所有字条加入完毕,每人从箱中取一个字条;
最后,如果取得的字条上写的就是自己的名字,那么“恭喜你,中奖了!”
大家可以想象一下当时的气氛之热烈,毕竟中奖者的奖品是大家梦寐以求的Twins签名照呀!不过,正如所有试图设计的喜剧往往以悲剧结尾,这次抽奖活动最后竟然没有一个人中奖!
我的神、上帝以及老天爷呀,怎么会这样呢?
不过,先不要激动,现在问题来了,你能计算一下发生这种情况的概率吗?
不会算?难道你也想以悲剧结尾?
Input
输入数据的第一行是一个整数C,表示测试实例的个数,然后是C 行数据,每行包含一个整数n(1<n<=20),表示参加抽奖的人数。
Output
对于每个测试实例,请输出发生这种情况的百分比,每个实例的输出占一行, 结果保留两位小数(四舍五入),具体格式请参照sample output。
Sample Input
12
Sample Output
50.00%
Author
lcy
#include<iostream> //hdu.2048#include<cstdio>using namespace std;long long wrongSortSum[25];//错排列的个数long long wrongSort(int n){ wrongSortSum[1]=0,wrongSortSum[2]=1; if(n>=3) for(int i=3;i<=n;i++) { wrongSortSum[i]=(i-1)*(wrongSortSum[i-1]+wrongSortSum[i-2]); } //cout<<wrongSortSum[n]<<endl; return wrongSortSum[n];}int main(){ int t; cin>>t; while(t--) { int n; cin>>n; long long sortSum=1;//全排列的个数 for(int i=1;i<=n;i++) sortSum*=i; double ans; ans=(double)wrongSort(n)/sortSum*100; //cout<<"sortSum: "<<sortSum<<endl; //cout<<ans<<endl; printf("%.2lf%%\n",ans); } return 0;}
0 0
- 全错位排列
- 全错位排列
- 全错位排列
- 全错位排列
- 全错位排列问题
- 全错位排列
- 全错位排列
- 全错位排列
- hdu(2048)全错位排列
- 全错位排列 配对概率问题
- 全错位排列递推分析
- HDU2048全错位排列 关于抽奖
- HDU2049 全错位排列加上组合数
- 错位排列
- 错位排列
- 错位排列
- ZZULIOJ-1876 礼上往来(全错位排列)
- 概率论 --- 对于全错位排列概率公式的证明推导
- 软件项目开发工具库积累
- 6.10.1 Android 推送中的心跳连接的概念
- PIPE和socketpair的区别
- Jmeter之Http Cookie Manager
- DC4C代码阅读(3)——代码目录结构
- 全错位排列
- HDU 2612 Find a way BFS 2次广搜
- 【Linux 基础篇】之网络、语言、级别等配置
- 【css】display与position
- iOS越狱检测总结及代码实现(JailBreak)
- PreparedStatement和Statement的用法区别
- SubShader 中的标签-LOD
- 【POJ】1789 - Truck History(克鲁斯塔尔)
- DC4C代码阅读(4)——注册节点:register node