7050 - 字串变换

通过次数

5

提交次数

8

时间限制 : 1 秒
内存限制 : 125 MB

已知有两个字串A,B及一组字串变换的规则(至多6个规则):

A1 -> B1

A2 -> B2

规则的含义为:在 A中的子串A1可以变换为B1、A2可以变换为B2...
 

例如:A='abcd' B='xyz'

变换规则为:

'abc'->'xu' 'ud'->'y' 'y'->'yz'

则此时,A$可以经过一系列的变换变为B,其变换的过程为:

'abcd'->'xud'->'xy'->'xyz'

共进行了三次变换,使得A变换为B。

输入

每个测试文件只包含一组测试数据,每组输入的第一行输入两个字符串A和B。

接下来若干行输入变换规则:

A B
A1 B1 \
A2 B2  |-> 变换规则
... ...      /

所有字符串长度的上限为 20。

输出

对于每组输入数据,若在10步(包含10步)以内能将A变换为B,则输出最少的变换步数,否则输出"NO ANSWER!"(不包含引号)。

样例

输入

abcd wyz
abc xu
ud y
y yz

输出

3

来源

NOIP