luogu#P8639. [蓝桥杯 2016 国 B] 生成树计数

    ID: 12624 远端评测题 4500ms 256MiB 尝试: 0 已通过: 0 难度: 6 上传者: 标签>动态规划,dp2016状态压缩蓝桥杯国赛

[蓝桥杯 2016 国 B] 生成树计数

题目描述

给定一个 n×mn×m 的格点图,包含 nnmm 列共 n×mn×m 个顶点,相邻的顶点之间有一条边。

给出了一个 3×43×4 的格点图的例子。

如果在图中删除部分顶点和其相邻的边,如上图删除第 22 行第 33 列和第 33 行第 11 列的顶点后,如下图所示。

图的生成树指包含图中的所有顶点和其中的一部分边,使得任意两个顶点之间都有由边构成的唯一路径。如果两个生成树包含有不同的边即被认为不同,则上图中共有 3131 种不同的生成树,其中 a 边不选有 1010 种,a 边选有 2121 种。

给出格点图中保留的顶点的信息,请计算该图一共有多少种不同的生成树。

输入格式

输入的第一行包含两个整数 nnmm,用空格分隔,表示格点图的行数和列数。

接下来 nn 行,每行 mm 个字母(中间没有分隔字符),每个字母必然是大写 E 或大写 NE 表示对应的顶点存在,N 表示对应的顶点不存在。保证存在至少一个顶点。

输出格式

输出一行,包含一个整数,表示生成树的个数。答案可能很大,你只需要计算答案除以 10000000071000000007(即 109+710^9+7) 的余数即可。

3 4
EEEE
EENE
NEEE
31

提示

对于 10%10\% 的数据,1n21\le n\le2

对于 30%30\% 的数据,1n31\le n\le3

对于 40%40\% 的数据,1n41\le n\le4

对于 50%50\% 的数据,1n51\le n\le5

另有 20%20\% 的数据,1n×m121\le n\times m\le12

另有 10%10\% 的数据,1m151\le m\le15

对于 100%100\% 的数据,1n61m1051\le n\le6,1\le m\le10^5