A. 【例题1】错排问题


题目描述

求多少个

n

n

n个数的排列

A

A

A ,满足对于任意的

i

(

1

i

n

)

i(1 ≤ i ≤ n)

i(1≤i≤n) 使

A

i

i

Ai ≠ i

Ai​=i 。


输入格式

一个整数 。


输出格式

一个整数,表示答案。


样例

  • 输入样例

2

  • 输出样例

1


数据范围与提示

对于

100

%

100\%

100%的数据,

1

n

20

1 ≤ n ≤ 20

1≤n≤20。


题目解析

首先这道题我们考虑递推;

首先,先以

f

(

1

)

=

0

,

f

(

2

)

=

1

f(1) = 0,f(2) = 1

f(1)=0,f(2)=1.(手推

1

,

2

1,2

1,2项您总会吧)
再从

3

3

3开始进行递推.

考虑从

n

n

n个数分别放在不同的位置有

n

n

n种方法,那么不放在原位就有

n

1

n-1

n−1种方法.
再考虑从

n

n

n中提取一个数

l

l

l.
考虑两种情况

  1. l

    l

    l放在原位上:那么除

    l

    l

    l外的

    n

    1

    n-1

    n−1个数的方法就为

    f

    (

    n

    2

    )

    f(n-2)

    f(n−2)
    (

    n

    1

    n-1

    n−1个数放在不同的位置,有

    n

    1

    n-1

    n−1种方法)

  2. 不把

    l

    l

    l放在原位上:那么对于剩余的

    n

    1

    n-1

    n−1个数就可以放在任何位,那么就是

    f

    (

    n

    1

    )

    f(n-1)

    f(n−1)种方法(同

    n

    n

    n个数分别放在不同的位置,不放在原位的就是

    l

    l

    l)

那么我们就很容易可以得出递推式:

f

(

i

)

=

{

f

(

1

)

=

0

f

(

2

)

=

1

f

(

i

)

=

(

n

1

)

(

f

(

n

1

)

+

f

(

n

2

)

)

(

i

>

2

)

f(i) = \left\{\begin{matrix} &~~~~~~~f(1) = 0~~~~~~~~~f(2) = 1~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ \\ & f(i) = (n - 1) * (f(n-1)+f(n-2)) ~~~~~~~~~~~(i>2)\\ \end{matrix}\right.

f(i)={​       f(1)=0         f(2)=1                                                         f(i)=(n−1)∗(f(n−1)+f(n−2))           (i>2)​


Code

小小的提醒:

20

20

20的数据也要开

l

o

n

g

long

long

l

o

n

g

long

long

#include <cstdio>
#include <iostream>
#define ll long long
using namespace std; ll n, ans, a[25]; int main ()
{
scanf ("%lld", &n);
a[2] = 1;
for (int i = 3; i <= n; ++ i)
a[i] = (i - 1) * (a[i - 1] + a[i - 2]);
printf ("%lld", a[n]);
return 0;
}

[递推] A. 【例题1】错排问题的更多相关文章

  1. HDU 2068 RPG的错排

    要求答对一半或以上就算过关,请问有多少组答案能使他顺利过关. 逆向思维,求答错一半或以下的组数 1,错排 错排公式的由来 pala提出的问题: 十本不同的书放在书架上.现重新摆放,使每本书都不在原来放 ...

  2. 致初学者(四):HDU 2044~2050 递推专项习题解

    所谓递推,是指从已知的初始条件出发,依据某种递推关系,逐次推出所要求的各中间结果及最后结果.其中初始条件或是问题本身已经给定,或是通过对问题的分析与化简后确定.关于递推的知识可以参阅本博客中随笔“递推 ...

  3. HDU 2048:神、上帝以及老天爷(错排公式,递推)

    神.上帝以及老天爷 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total ...

  4. ACM_错排(递推dp)

    RPG的错排 Time Limit: 2000/1000ms (Java/Others) Problem Description: 今年暑假GOJ集训队第一次组成女生队,其中有一队叫RPG,但做为集训 ...

  5. 错排-HDU 2049 递推的应用

    当n个编号元素放在n个编号位置,元素编号与位置编号各不对应的方法数用M(n)表示,那么M(n-1)就表示n-1个编号元素放在n-1个编号位置,各不对应的方法数,其它类推. 第一步,把第n个元素放在一个 ...

  6. 不容易系列之一(hdu1465)错排+递推

    不容易系列之一 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  7. HDU 2048 神、上帝以及老天爷 【递推】【错排】

    题目链接 Problem Description HDU 2006'10 ACM contest的颁奖晚会隆重开始了!为了活跃气氛,组织者举行了一个别开生面.奖品丰厚的抽奖活动,这个活动的具体要求是这 ...

  8. 神、上帝以及老天爷--hdu2048(错排,递推)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2048 1. N张字条的所有可能排列自然是N!(分母). 现在的问题就是求N张字条的错排数f(N)(分子 ...

  9. hdu2068-RPG的错排-(dp递推式)

    去年看错排公式,死都看不懂,基础扎实之后再来看就略懂了. 公式: dp[ n ] = ( n-1 ) * ( dp[n-1] + dp[n-2] ) 解析公式:比如有n个元素,各对应n个正确位置,dp ...

随机推荐

  1. redux & dispatch & payload

    redux & dispatch & payload react & react-redux & redux-saga // contrast dispatch({ t ...

  2. py python-pptx 创建ppt

    创建一个简单的PPTX文件 from pptx import Presentation class Main(): def __init__(self): prs = Presentation() t ...

  3. 行业动态 | Apache Pulsar 对现代数据堆栈至关重要的四个原因

    与 Kafka 相比,Pulsar 的架构使它在跨地域复制.扩展.多租户和队列等方面具有重要的优势.   1 月 27 日,DataStax 宣布收购Kesque(Pulsar 即服务),加入到了 P ...

  4. hadoop支持lzo完整过程

    简介 启用lzo 启用lzo的压缩方式对于小规模集群是很有用处,压缩比率大概能降到原始日志大小的1/3.同时解压缩的速度也比较快. 安装lzo lzo并不是linux系统原生支持,所以需要下载安装软件 ...

  5. net面试总结的题目

    准备的面试题目. 1.private.protected.public.internal的访问权限? private : 私有成员,在类的内部才可以访问. protected :保护成员,该类内部和继 ...

  6. Omega System Trading and Development Club内部分享策略Easylanguage源码 (第二期)

    更多精彩内容,欢迎关注公众号:数量技术宅,也可添加技术宅个人微信号:sljsz01,与我交流. 我们曾经在前文(链接),为大家分享我们精心整理的私货:"System Trading and ...

  7. (十三)数据库查询处理之QueryExecution(2)

    (十三)数据库查询处理之QueryExecution(2) 实验室这一周真的忙爆(虽然都是各种打杂的活)所以拖了很久终于在周末(摸鱼)把实验3做完了.同时准备把和查询这一块有关的博客补一下.然后就进入 ...

  8. swaks制作钓鱼邮件

      一.在网站:https://bccto.me/ 申请一个十分钟的邮箱 二.使用命令行,命令行解释如下: --from hacker@qq.com //发件人的邮箱 --ehlo qq.com // ...

  9. C语言入门--初来乍到

    Hi,我是fish-studio,这是我写的第一篇博客,接下来我会以萌新的角度来与大家一起学习C语言,我也不是什么大佬,在我写的教程中会尽量详细的把我遇到的问题写出来,也会结合一些网上的文章进行编写, ...

  10. python学习之基础内容

    python基础内容① 什么是python? -一种计算机语言,计算机语言分为 -高级语言:python.java.Ruby.C#.C++...... -基础语言:C语言.汇编 -计算机可以直接执行基 ...