#5083. Problem 1. Redistributing Gifts

0

Problem 1. Redistributing Gifts

Problem 1. Redistributing Gifts

USACO 2022 February Contest, Gold

Farmer John 为他的 NN 头编号为 1N1\ldots N 的奶牛准备了 NN 个同样编号为 1N1\ldots N 的礼物(1N181\le N\le 18)。每头奶牛都有一个愿望单,是所有 NN 个礼物的一个排列,奶牛相比序列中较晚出现的礼物更喜欢序列中较早出现的礼物。

FJ 很懒,只是对于所有 ii 将礼物 ii 分配给奶牛 ii。现在,奶牛们自行聚集在一起并决定重新分配礼物,使得在重新分配后,每头奶牛最终得到的是她最初得到的礼物,或者比她最初得到的礼物更喜欢的礼物。

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

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

输入的第一行包含 NN

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

以下一行包含 QQ

最后 QQ 行每行包含一个品种字符串,长度为 NN 且仅由字符 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

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

  • 初始的分配方式:奶牛 11 收到礼物 11,奶牛 22 收到礼物 22,奶牛 33 收到礼物 33,奶牛 44 收到礼物 44
  • 奶牛 11 收到礼物 11,奶牛 22 收到礼物 33,奶牛 33 收到礼物 22,奶牛 44 收到礼物 44

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

测试点性质: 对于 T=2,,13T = 2, \ldots, 13,测试点 TT 满足 N=T+4N = T + 4。测试点 14-18 满足 N=18N = 18

供题:Benjamin Qi