题目背景
本题疑似错题,不保证存在靠谱的多项式复杂度的做法。测试数据非常的水,各种做法都可以通过,不代表算法正确。因此本题题目和数据仅供参考。
题目描述
已知有两个字串 A,BA,BA,B 及一组字串变换的规则(至多 666 个规则),形如:
- A1→B1A_1\to B_1A1→B1。
- A2→B2A_2\to B_2A2→B2。
规则的含义为:在 AAA 中的子串 A1A_1A1 可以变换为 $ B_1,,,A_2$ 可以变换为 B2⋯B_2\cdotsB2⋯。
例如:A=abcdA=\texttt{abcd}A=abcd,B=xyzB=\texttt{xyz}B=xyz,
变换规则为:
- abc→xu\texttt{abc}\rightarrow\texttt{xu}abc→xu,ud→y\texttt{ud}\rightarrow\texttt{y}ud→y,y→yz\texttt{y}\rightarrow\texttt{yz}y→yz。
则此时,AAA 可以经过一系列的变换变为 BBB,其变换的过程为:
- abcd→xud→xy→xyz\texttt{abcd}\rightarrow\texttt{xud}\rightarrow\texttt{xy}\rightarrow\texttt{xyz}abcd→xud→xy→xyz。
共进行了 333 次变换,使得 AAA 变换为 BBB。
输入格式
第一行有两个字符串 A,BA,BA,B。
接下来若干行,每行有两个字符串 Ai,BiA_i,B_iAi,Bi,表示一条变换规则。
输出格式
若在 101010 步(包含 101010 步)以内能将 AAA 变换为 BBB,则输出最少的变换步数;否则输出 NO ANSWER!。
样例 #1
样例输入 #1
abcd xyz
abc xu
ud y
y yz
样例输出 #1
3
提示
对于 100%100\%100% 数据,保证所有字符串长度的上限为 202020。
【题目来源】
NOIP 2002 提高组第二题
文章讨论了一个字符串A到字符串B的字串变换问题,规则最多6条,目标是在10步内将A转换为B。给出两个字符串A和B以及一系列变换规则,求解在限制步数内能否实现转换,如果可以,输出最小步数;否则输出NOANSWER!
748

被折叠的 条评论
为什么被折叠?



