Logo HelloWorld信息学奥赛题库

少儿编程

时间限制:1 s 空间限制:512 MB

#4187. 「2017 山东三轮集训 Day5」Fantasy

统计

题目描述

JOHNKRAM 收到了一个字符串 $ S $,但他不喜欢这个串,他决定把它变成 $ T $。

JOHNKRAM 最近学习了一些后缀数据结构,他相信通过替换后缀可以实现一切操作。他有 $ m $ 种替换方式,每种替换方式包含两个等长的字符串 $ u $ 和 $ v $,如果当前 $ u $ 是 $ S $ 的后缀,则可以将 $ S $ 的后缀 $ u $ 替换成 $ v $。

现在 JOHNKRAM 希望你能帮他计算出,最少需要替换多少次才能将 $ S $ 变成 $ T $。

输入格式

一个测试点包含多组数据。
每组数据第一行包含两个字符串 $ S $ 和 $ T $ 以及一个整数 $ n $,意思如题所示。
接下来 $ n $ 行每行两个字符串 $ u $ 和 $ v $,表示一种替换方式。
输入文件以一个 . 结束。

输出格式

对于每一组数据,输出该组数据编号以及最小步数,如果无解输出 No Solution。格式参见样例。

样例

input

AA BB 4
A B
AB BA
AA CC
CC BB
A B 3
A C
B C
c B
.

output

Case 1: 2
Case 2: No solution

数据范围与提示

对于 $ 30\% $ 的数据,字符串长度 $ \leq 1 $;
对于 $ 45\% $ 的数据,字符串长度 $ \leq 5 $;
对于 $ 100\% $ 的数据,字符串长度 $ \leq 20, 1 \leq n \leq 100 $,字符集为大小写字母。