NYOJ 912 领帽子(全错位排列)
领帽子
时间限制:1000 ms | 内存限制:65535 KB
难度:2
描述
有n个人在参加晚会时寄存了自己的帽子。可是保管人忘记放寄存号,当每个人领取帽子时,他只能随机选择一顶帽子交给寄存人。问在n!种领取帽子的方式中有多少种方式使得每个人都没有领到自己的帽子?要注意咯,是使得每个人都没有领到自己的帽子,比如有A、B、C三个人,则有两种方案即:A领B的,B领C的,C领A的,另外一种:A领C的,B领A的,C领B的。明白了吧~~
输入
输入有多组测试数组。
每组测试数据占一行,每行输入一个整数n(1<=n<=15)表示有n个人。
输出
每组测试输出一个数占一行,表示有多少种方法。
样例输入
2
3
1
样例输出
1
2
0
AC code
#include <iostream>
using namespace std;
int main()
{
long long a[20];
a[1]=0;
a[2]=1;
int t;
for(int i=3;i<=15;i++)
a[i]=(i-1)*(a[i-1]+a[i-2]);
while(cin>>t)
cout<<a[t]<<endl;
return 0;
}
---------------------------------------------------------
全错位排列
全错位排列:即被著名数学家 欧拉(Leonhard Euler,1707-1783)称为组合数论的一个妙题的“装错信封问题”。
基本简介
“装错信封问题”是由当时最有名的数学家 约翰·伯努利(Johann Bernoulli,1667-1748)的儿子 丹尼尔·伯努利(DanidBernoulli,1700-1782)提出来的,大意如下:
一个人写了n封不同的信及相应的n个不同的信封,他把这n封信都装错了信封,问都装错信封的装法有多少种?
公式证明
n个相异的元素排成一排a1,a2,...,an。则ai(i=1,2,...,n)不在第i位的排列数为:
证明:
设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∩...∩An|=0!=1。
由 容斥原理:
Dn=n!-|A1∪A2∪...∪An|=n!-C(n,1)(n-1)!+C(n,2)(n-2)!-C(n,3)(n-3)!+...+(-1)^nC(n,n)*0!
=n!(1-1/1!+1/2!-1/3!+...+(-1)^n*1/n!)
2应用
编辑
简单排列
1个元素没有全错位排列,2个元素的全错位排列有1种,3个元素的全错位排列有2种,4个元素的全错位排列有9种,5个元素的全错位排列有44种。
递推公式
瑞士数学家欧拉按一般情况给出了一个递推公式:
用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)}
公式可重新写成 f(n)-nf(n-1)=-[f(n-1)-(n-1)f(n-2)] (n>2)
于是可以得到
f(n)-nf(n-1)=-[f(n-1)-(n-1)f(n-2)]
=((-1)^2)[f(n-2)-(n-2)f(n-3)]
=((-1)^3)[f(n-3)-(n-3)f(n-4)]
=……
=[(-1)^(n-2)][f(2)-2f(1)]
最终得到一个更简单的递推式 f(n)=nf(n-1)+(-1)^(n-2)
或者等价式 f(n)=nf(n-1)+(-1)^(n) n=2,3,4……
NYOJ 912 领帽子(全错位排列)相关推荐
- 广东工业大学2017新生赛(决赛)-网络同步赛 1007 白色相簿的季节【全错位排列】
白色相簿的季节 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) Total Submi ...
- 全错位排列 配对概率问题
全错位排列 先看下面例子: 例1 5个人站成一排,其中甲不站第一位,乙不站第二位,共有多少种不同的站法. 这个问题在高中很多参考书上都有,有几种解法,其中一解法是用排除法: 先考虑5个有的 ...
- 全错位排列与部分错位排列(组合数学)
全错位排列 基本简介 "装错信封问题"是由当时最有名的数学家约翰·伯努利(Johann Bernoulli,1667-1748)的儿子丹尼尔·伯努利(DanidBernoulli, ...
- 经典算法题:全错位排列问题
问题描述 这是一个很经典的数学问题:有一个人写了n封信件,对应n个信封,然而粗心的秘书却把所有信件都装错了信封,那么一共有多少种装错的装法? 数学抽象 这个问题可抽象为以下一个数学问题:已知一个长度为 ...
- 【组合数学】全错位排列的递推公式推导
简介 假设现在我有三个信封A,B,C,并且现在有三个信纸a,b,c. 按照道理的话是,a塞入A信封,b塞入B信封,c塞入C信封. 但是现在,想要问,对于a,b,c全部塞错的情况,有多少种呢? 比如把b ...
- 错位排列超详解(组合数学)
错位排列 全错位排列最经典的问题是装错信封问题. 我们把信封问题转换一下: 对于1−n1-n1−n 共n个数字组成的序列中,每个数字仅出现一次,求每个数字跟位置完全不对应的总方案数. 对于第一个位置上 ...
- hdu2048 全错位排序问题
hdu2048是全错位排序的题目!欧拉给我们证明了可以直接套用公式 f(n)= nf(n-1)+(-1)^(n-2) 或 nf(n-1)+(-1)^(n) n ...
- LeetCode-Python-634. 寻找数组的错位排列(数学 + 错排公式)
在组合数学中,如果一个排列中所有元素都不在原先的位置上,那么这个排列就被称为错位排列. 给定一个从 1 到 n 升序排列的数组,你可以计算出总共有多少个不同的错位排列吗? 由于答案可能非常大,你只需要 ...
- One Day One Step 之全错位排序
One Day One Step 之全错位排序 今天做了一道题,是关于全错位排序的.在高中的时候,对排列组合一直很头痛,所以今天趁这个机会,好好学习学习! 先来看一下题目吧! 神.上帝以及老天爷 ...
最新文章
- 深入聊一聊 Spring AOP 实现机制
- VC获取系统时间、程序运行时间
- 【Android 逆向】Android 逆向基本概念 ( 软件运行时内存结构 | 文件与内存之间的联系 )
- 转换环境与执行环境、宿主环境与独立环境、宿主实现与独立实现
- 对称振子天线matlab程序,对称振子天线详解.ppt
- window实用快捷键
- 更新node_kubernetes证书更新
- Kibana未授权访问漏洞记录(CVE-2019-7609,Kibana的RCE,原型链污染,端口:5601)
- Network | DNS
- MySQL Workbench 的安全设置
- numpy教程:基本输入输出和文件输入输出Input and output
- 7-5 有理数比较 (10 分)
- 初学者该掌握的计算机知识,初学者该如何学习电脑知识
- 7654:等差数列末项计算
- 微信小程序报错unshift is not a function
- JavaWeb web.xml配置详解
- android ellipsize 属性详解
- TortoiseSVN安装最新版,设置中文;并修改比对工具为BeyondCompare
- WKT、SRID、EPSG概念
- python 工作流workflow_Workflow笔记1——工作流介绍