RPG的错排

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)

Total Submission(s): 8996    Accepted Submission(s): 3699

Problem Description
今年暑假杭电ACM集训队第一次组成女生队,当中有一队叫RPG,但做为集训队成员之中的一个的野骆驼居然不知道RPG三个人详细是谁谁。RPG给他机会让他猜猜,第一次猜:R是公主。P是草儿。G是月野兔。第二次猜:R是草儿。P是月野兔,G是公主;第三次猜:R是草儿,P是公主。G是月野兔;......可怜的野骆驼第六次最终把RPG分清楚了。因为RPG的带动,做ACM的女生越来越多,我们的野骆驼想都知道她们。可如今有N多人,他要猜的次数可就多了,为了不为难野骆驼,女生们仅仅要求他答对一半或以上就算过关,请问有多少组答案能使他顺利过关。
 
Input
输入的数据里有多个case,每一个case包含一个n,代表有几个女生。(n<=25), n = 0输入结束。

 
Sample Input
  1. 1
  2. 2
  3. 0
 
Sample Output
  1. 1
  2. 1
  3. 此处运用了错排公式,错排公式具体解释例如以下:
  4. 错排公式具体解释:
  5. n个编号元素放在n个编号位置,元素编号与位置编号各不正确应的方法数用M(n)表示,那么M(n-1)就表示n-1个编号元素放在n-1个编号位置,各不正确应的方法数,其他类推.
  6. 第一步,把第n个元素放在一个位置,比方位置k,一共同拥有n-1种方法;
  7. 第二步,放编号为k的元素,这时有两种情况.1,把它放到位置n,那么,对于剩下的n-2个元素,就有M(n-2)种方法;2,不把它放到位置n,这时,对于这n-2个元素,有M(n-1)种方法;
  8. 综上得到
  9. D(n) = (n - 1) * [D(n - 2) + D(n - 1)]
  10. D(1) = 0,D(2) = 1
  11. 如今解说大家疑惑的地方,或许大家对于那个D(n - 2)不疑惑。可是对于D(n - 1)的来由有点坑爹
  12. 如今进行解说,当将n这个位置的元素放在了k这个位置,那么此时将k这个位置放在n的位置,当作是k本来不是在k的位置。而是在n的位置
  13. 或许大家有点听不懂。以下有图形说明:
  14. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
  15.  
  16. 这幅图表示最開始正确的序列

  17. 这幅图表示第八个与第四个进行交换了
  18.  
  19. 接着就是重中之重
  20.  
  21. 所谓的d[i - 1] * (i - 1)的由来就是上面这幅图,将4这个数原本的位置不再看成是第一幅的位置。而是上面这幅图的位置,那么这个图的错排就是d[i - 1] * (i - 1)
  22.  
  23. 第二种easy理解的思路
  24. 因为
  25. D[i - 1]中多加了一个元素f[i]那么这个元素能够放在D[i - 1]中错排序列中随意个,所以有(i - 1) * D[i - 1]中,
  26. 然后是假设i - 1个数中有一个没有进行错排,那么这个数与f[i]进行交换。接着剩下的全部元素进行错排有(i - 1) * D[i - 2]个
  27. 如此答案为D(n) = (n - 1) * [D(n - 2) + D(n - 1)]
  28.  
  29. #include <cstdio>
  30. #include <cstring>
  31. #include <algorithm>
  32. using namespace std;
  33. typedef long long LL;
  34. LL ans[20];
  35. int n;
  36. LL getsd(LL n,LL x) {
  37.     LL ret = 1;
  38.     for(int i = 0; i < x; i ++) {
  39.         ret = ret * (n - i) /(i + 1);
  40.     }
  41.     return ret;
  42. }
  43. int main() {
  44.     ans[0] = 1;
  45.     ans[1] = 0;
  46.     ans[2] = 1;
  47.     for(int i = 3; i <= 15 ; i ++) {
  48.         ans[i] = (ans[i - 1] + ans[i - 2]) * (i - 1);
  49.     }
  50.     while(~ scanf("%d", &n), n) {
  51.         LL ret = ans[0];
  52.         int m = n >> 1;
  53.         for(int i = 1; i <= m; i ++) {
  54.             ret += ans[i] * getsd(n,i);
  55.         }
  56.         printf("%I64d\n",ret);
  57.     }
  58.     return 0;
  59. }
 

HDU 2068 RPG的错排(错排公式 + 具体解释)的更多相关文章

  1. HDU 2068 RPG的错排

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

  2. [HDU 2068] RPG的错排 (错排问题)

    RPG的错排 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2068 题目大意: 有N个人对应N个名字,然后你去把每一个名字对应到每个人,只要求答对一半 ...

  3. HDU 2068 RPG错排 [错排公式]

    1.题意:1到N的序列的排列中,元素位置与元素值相对应的情况(值为i的元素在某个排列中正好排在第i个位置)大于等于序列规模一半的情况,有多少个? 2.输入输出:每组数据一个数,N,规定输入以0结尾: ...

  4. hdu2068 RPG的错排 错排+组合

    RPG的错排 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Subm ...

  5. HDOJ(HDU) 1465 不容易系列之一(错排)

    Problem Description 大家常常感慨,要做好一件事情真的不容易,确实,失败比成功容易多了! 做好"一件"事情尚且不易,若想永远成功而总从不失败,那更是难上加难了,就 ...

  6. hdu 1465 不容易系列之一(错排模板)

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

  7. HDU2068 RPG的错排 —— 错排

    题目链接:https://vjudge.net/problem/HDU-2068 RPG的错排 Time Limit: 1000/1000 MS (Java/Others)    Memory Lim ...

  8. HDU 1465 不容易系列之一(错排,递归)

    简而言之,就是把n个信封全部装错的可能数.(中问题,具体看题目) //当n个编号元素放在n个编号位置,元素编号与位置编号各不对应的方法数用M(n)表示, //那么M(n-1)就表示n-1个编号元素放在 ...

  9. 【js基础】js排序方法——快排+堆排+插排+选择排

    快排 Array.prototype.fastSort = function(){ var arr = this; function sort(left, right, arr){ if( left ...

随机推荐

  1. 对Jscript操作注册表接口的一点不解

    作者:朱金灿 来源:http://blog.csdn.net/clever101 要操作注册表需要通过ActiveX控件调用WScript.shell对象,通过该对象的一些方法来操作.Wshshell ...

  2. codeforces 710C Magic Odd Square(构造或者n阶幻方)

    Find an n × n matrix with different numbers from 1 to n2, so the sum in each row, column and both ma ...

  3. JS对象继承与原型链

    1.以复制方式实现的继承 1.1浅拷贝 基本类型的复制 var parent = { lanage: "chinese" } var child = { name: "x ...

  4. 关于Echarts表格插件的使用

    <template> <div :style="{height:height,width:width}"></div> </templat ...

  5. Tensorflow 学习笔记 -----tf.where

    TensorFlow函数:tf.where 在之前版本对应函数tf.select 官方解释: tf.where(input, name=None)` Returns locations of true ...

  6. 【Redis发布订阅】

    Redis通过PUBLISH.SUBSCRIBE等命令实现发布与订阅模式. 举例:QQ群的公告,单个发布者,多个收听着. *** 发布/订阅 PUBLISH 频道 消息 将消息发布到指定的频道. . ...

  7. 【Linux下自定义Shell终端提示符】

    目录 基本转义符 字体颜色 背景颜色 移动光标 @ Linux系统终端提示符的特征由系统环境变量 PS1(Prompt String One)定义. 我们可以通过命令echo $PS1来查看当前设置, ...

  8. 【玲珑杯 round#18 B】图论你先敲完模板

    [Link]:http://www.ifrog.cc/acm/problem/1146 [Description] [Solution] 设f[i]表示在第i个点休息的话最少需要的体力值; f[i]= ...

  9. I帧、P帧和B帧的特点

    I帧:帧内编码帧 I帧特点: 1.它是一个全帧压缩编码帧.它将全帧图像信息进行JPEG压缩编码及传输; 2.解码时仅用I帧的数据就可重构完整图像; 3.I帧描写叙述了图像背景和运动主体的详情; 4.I ...

  10. amlogic M8操作gpio bank

    參照规格书: r代表:读 a代表GPIOAO bank 0x28代表read bit echo r a 0x28 > /sys/class/amlogic/debug 操作GPIO口读取 w代表 ...