A92078.「POI 1997」基因串
省选/NOI-
通过率:0%
时间限制:1.00s
内存限制:32MB
题目描述
译自 POI 1997 Round II Day1 T2「Genotype」
Genotype 是一个有限的基因序列。它是由大写的英文字母 A∼Z 组成,不同的字母表示不同种类的基因。一个基因可以分化成为一对新的基因。这种分化被一个定义的规则集合所控制。每个分化的规则可以用三个大写字母 A1A2A3 表示,含义为基因 A1 可以分化成 A2A3。
我们用 S 代表特种基因,繁殖 Genotype 是从特种基因序列开始。根据给定的规则,它由被选择控制规则对基因不断进行繁殖而成。
读入一个定义的规则集和一个想生成的 Genotypes 单词序列 。
对每一个给定的 Genotype,根据给定的分化规则,检查是否它能从某一个确定特种基因序列生成,如果能,输出最小的序列长度。
输入格式
第一行有一个整数 n, 1≤n≤10000。
下面 n 行中,每一行为一个分化规则。这些规则都由包含 A∼Z 的三个大写字母组成。
接下来有一个整数 k, 1≤k≤10000。 接下来的 k 行有一个 Genotype。Genotype 由没有空格的单词组成,最多 100 个英文大写字母。
输出格式
有 k 行,在第 I 行应写入:一个正整数――需要生成第 I 个 genotypes 的最小长度;
或者单词 NIE, 如果不能生成对应的 genotype。
输入输出样例
输入#1
6 SAB SBC SAA ACA BCC CBC 3 ABBCAAABCA CCC BA
输出#1
3 1 NIE