bzoj#P1867. [NOI1999]钉子和小球

[NOI1999]钉子和小球

题目描述

有一个三角形木板,竖直立放,上面钉着 n(n+1)2\frac{ n (n+1) } { 2 } 颗钉子,还有 n+1n+1 个格子 (当 n=5n=5 时如图 1 )。每颗钉子和周围的钉子的距离都等于 dd,每个格子的宽度也都等于 dd,且除了最左端和最右端的格子外每个格子都正对着最下面一排钉子的间隙。

让一个直径略小于 dd 的小球中心正对着最上面的钉子在板上自由滚落,小球每碰到一个钉子都可能落向左边或右边 (概率各 50%50\%)我们知道小球落在第 ii 个格子中的概率 pi=Cni2n=n!2ni!(ni)!p_i=\frac{C_n^i}{2^n}=\frac{ n! }{ 2^n i! (n-i)! },其中 ii 为格子的编号,从左至右依次为 0,1,,n0,1,\cdots,n

现在的问题是计算拔掉某些钉子后,小球落在编号为 mm 的格子中的概率 pmp_m。假定最下面一排钉子不会被拔掉。例如图 33 是某些钉子被拔掉后小球一条可能的路径。

a

上面三个图分别为图 1,2,31,2,3

输入格式

第一行为整数 nnmm

以下 nn 行依次为木板上从上至下 nn 行钉子的信息,每行中*表示钉子还在,.表示钉子被拔去,注意在这 nn 行中空格符可能出现在任何位置。

输出格式

仅一行,是一个既约分数(00 写成 0/10/1),为小球落在编号为 mm 的格子中的概率 pmp_m

既约分数的定义:a/ba/b 是既约分数,当且仅当 a,ba,b 为正整数且 aabb 没有大于 11 的公因子。

样例

5 2
    *  
   * .
  * * *
 * . * *
* * * * *
7/16

数据规模与约定

对于所有数据,1n501\le n\le 500mn0\le m\le n