#U2122FG1. Redistributing Gifts

Redistributing Gifts

Farmer John 为他的 N 头编号为 1…N 的奶牛准备了 N 个同样编号为 1…N 的礼物(1≤N≤18)。每头奶牛都有一个愿望单,是所有 N 个礼物的一个排列,奶牛相比序列中较晚出现的礼物更喜欢序列中较早出现的礼物。FJ 很懒,只是对于所有 i 将礼物 i 分配给奶牛 i。现在,奶牛们自行聚集在一起并决定重新分配礼物,使得在重新分配后,每头奶牛最终得到的是她最初得到的礼物,或者比她最初得到的礼物更喜欢的礼物。

还有一个额外的限制:如果礼物最初分配给一头奶牛,则只能将礼物重新分配给同一品种的奶牛(每头奶牛是荷斯坦牛(Holstein)或更赛牛(Guernsey)之一)。给定 Q(1≤Q≤min(105^5,2N^N))个长为 N 的品种字符串,对每个字符串计算其对应的重新分配方法数。

输入格式(从终端 / 标准输入读入):

输入的第一行包含 N。以下 N 行每行包含一头奶牛的愿望单。输入保证每行均为 1…N 的一个排列。

以下一行包含 Q。

最后 Q 行每行包含一个品种字符串,长度为 N 且仅由字符 G 和 H 组成。没有品种字符串会出现超过一次。

输出格式(输出至终端 / 标准输出):

对于每一个品种字符串,输出一行,包含其对应的重新分配方法数。

输入样例:

4
1 2 3 4
1 3 2 4
1 2 3 4
1 2 3 4
5
HHHH
HHGG
GHGH
HGGG
GHHG

输出样例:

2
1
1
2
2

在这个例子中,对于第一个品种字符串,有两种可能的重新分配方式:

  • 初始的分配方式:奶牛 1 收到礼物 1,奶牛 2 收到礼物 2,奶牛 3 收到礼物 3,奶牛 4 收到礼物 4。
  • 奶牛 1 收到礼物 1,奶牛 2 收到礼物 3,奶牛 3 收到礼物 2,奶牛 4 收到礼物 4。

对于第二个品种字符串,与之对应的唯一重新分配方式即为初始的分配方式。

测试点性质:

  • 对于 T=2,…,13,测试点 T 满足 N=T+4。
  • 测试点 14-18 满足 N=18。