#D5328. Shik and Copying String

    ID: 4427 Type: Default 2000ms 268MiB

Shik and Copying String

Shik and Copying String

Shik's job is very boring. At day 0, his boss gives him a string S_0 of length N which consists of only lowercase English letters. In the i-th day after day 0, Shik's job is to copy the string S_{i-1} to a string S_i. We denote the j-th letter of S_i as S_i[j].

Shik is inexperienced in this job. In each day, when he is copying letters one by one from the first letter to the last letter, he would make mistakes. That is, he sometimes accidentally writes down the same letter that he wrote previously instead of the correct one. More specifically, S_i[j] is equal to either S_{i-1}[j] or S_{i}[j-1]. (Note that S_i[1] always equals to S_{i-1}[1].)

You are given the string S_0 and another string T. Please determine the smallest integer i such that S_i could be equal to T. If no such i exists, please print -1.

Constraints

  • 1 \leq N \leq 1,000,000
  • The lengths of S_0 and T are both N.
  • Both S_0 and T consist of lowercase English letters.

Input

The input is given from Standard Input in the following format:

N S_0 T

Output

Print the smallest integer i such that S_i could be equal to T. If no such i exists, print -1 instead.

Examples

Input

5 abcde aaacc

Output

2

Input

5 abcde abcde

Output

0

Input

4 acaa aaca

Output

2

Input

5 abcde bbbbb

Output

-1

inputFormat

Input

The input is given from Standard Input in the following format:

N S_0 T

outputFormat

Output

Print the smallest integer i such that S_i could be equal to T. If no such i exists, print -1 instead.

Examples

Input

5 abcde aaacc

Output

2

Input

5 abcde abcde

Output

0

Input

4 acaa aaca

Output

2

Input

5 abcde bbbbb

Output

-1

样例

5
abcde
abcde
0