http://acm.hdu.edu.cn/showproblem.php?pid=3625
题意描述:有n个紧锁的房间和这n个房间门上的n把钥匙,每个房间中随机锁了一把钥匙。你可以破坏一扇门,取出其中的钥匙,尝试用钥匙打开另外的门(然后取出钥匙去打开另外的门,或者接着破坏另外的门)。最多可以破坏k(<=n)扇门,但是第一扇门只能用钥匙打开。求所有门能被打开(被破坏,或是被钥匙打开)的概率。
传说中的第一类斯特林数。
如果用s[n][k]表示n个门中有k个环的情况数,则有:
s[n][k] = s[n - 1][k - 1] + (n - 1) * s[n - 1][k], 1 <= k <= n - 1
上面的公式可以这样理解:当前n - 1个门组成k - 1个环的时候,再加入第n个门形成一个单环即可;当n - 1个门组成k个环时,要加入第n个门,为了不增加环的个数,只需要将n插在前n - 1个门的任意一个门之后即可。
初始化情况为:
s[i][0] = 0;
s[i][i] = 1, i >= 1
因为第一个门不能在环中,只需将第一个门在环中的情况减去,即是s[i][j] - s[i - 1][j - 1]才是合法的情况。
以下是代码:

posted on 2012-09-06 20:39 小鼠标 阅读(1148) 评论(0)  编辑 收藏 引用 所属分类: 网选训练

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


<2012年9月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

常用链接

随笔分类(111)

随笔档案(127)

friends

最新评论

  • 1. re: 线段树
  • 是这个样子的,所以在OJ有时候“卡住”了也不要太灰心,没准真的不是自己的原因呢。
    加油,祝你好运啦!
  • --小鼠标
  • 2. re: 线段树
  • 对于编程竞赛来说,Java所需时间一般为C/C++的两倍。合理的竞赛给Java的时间限制是给C/C++的两倍。
  • --伤心的笔
  • 3. re: poj1273--网络流
  • 过来看看你。
  • --achiberx
  • 4. re: (转)ubuntu11.10无法启动无线网络的解决方法
  • 膜拜大神。。查了一个下午资料终于在这里解决了问题。。神牛说的区域赛难道是ACM区域赛。。?
  • --Hang
  • 5. re: 快速排序、线性时间选择
  • 博主,谢谢你的文章。你的方法可以很好的处理分区基准在数组中重复的情况,书上的方法遇到这种输入会堆栈溢出。书上给出了解释但给的方法貌似不简洁。
  • --lsxqw2004

阅读排行榜