B - Replace to the Other Editorial /

Time Limit: 2 sec / Memory Limit: 1024 MB

配点 : 400

問題文

A, B のみからなる長さ N の文字列 S, T が与えられます。以下の操作を 0 回以上繰り返すことで ST に一致させられるかを判定し、可能なら必要な操作回数の最小値を求めてください。

  • S_i=S_{i+1} であるような整数 i\ (1 \leq i \lt N) を選び、S_iS_{i+1}A, B のうち現在とは異なる文字にそれぞれ置き換える。

制約

  • 2 \leq N \leq 2 \times 10^5
  • S, TA, B のみからなる長さ N の文字列

入力

入力は以下の形式で標準入力から与えられる。

N
S
T

出力

問題文中の操作によって ST に一致させられるなら必要な操作回数の最小値を、一致させられないなら -1 を出力せよ。


入力例 1

3
AAB
BAA

出力例 1

2

例えば以下のような手順で操作を行うのが最善です。

  • i=1 として操作を行う。SBBB となる。
  • i=2 として操作を行う。SBAA となり、これは T に一致する。

入力例 2

3
ABA
AAA

出力例 2

-1

そもそも操作を一回も行うことができず、ST に一致させることはできないため、-1 を出力します。


入力例 3

4
ABAB
ABAB

出力例 3

0

ST が既に一致しているため、一度も操作を行う必要がありません。

原案: NatsubiSogan