Hide

Problem J
Power String Matching

For two strings $s_1$ and $s_2$, let $s_1 + s_2$ denote their concatenation, e.g. abc + cda is the string abccda.

Now for a string $s$ and an integer $k \geq 0$ we let $s^ k$ denote the result of concatenating $k$ copies of $s$, i.e. $\texttt{ab}^3 = \texttt{ababab}$. If $k = 0$, then $s^ k$ is just the empty string.

Finally, a collection of nonempty strings $s_1, \ldots , s_ k$ is said to partition a string $s$ if $s = s_1 + s_2 + \ldots + s_ k$.

For this problem, you will be given two strings $s, t$. The goal is to determine if there is a partition $s_1, s_2, \ldots , s_ k$ of $s$ and integers $a_1, a_2, \ldots , a_ k \geq 0$ such that $t = s_1^{a_1} + s_2^{a_2} + \ldots + s_ k^{a_ k}$.

Input

The first line of input contains two integers $N$ ($1 \leq N \leq 300$) and $M$ ($1 \leq M \leq 300$). The second line contains a string $s$ of length $N$ and the third line contains a string $t$ of length $M$. Both strings contain only the characters 0 and 1.

Output

Output yes if it there is a partition $s_1, s_2, \ldots , s_ k$ of $s$ and integers $a_1, a_2, \ldots , a_ k \geq 0$ such that $t = s_1^{a_1} + s_2^{a_2} + \ldots + s_ k^{a_ k}$, otherwise output no.

Sample Input 1 Sample Output 1
4 5
1100
11010
yes
Sample Input 2 Sample Output 2
4 2
1100
01
no
Sample Input 3 Sample Output 3
9 14
010100110
11110101010100
yes

Please log in to submit a solution to this problem

Log in