P15807 [JOI 2013 Final] IOI 列車で行こう
Description
IOI 国ではこのたび新たに鉄道を敷設した.IOI 国の鉄道を走る列車はいくつかの車両が連結されたものであり,車両には **I**, **O** の 2 種類がある.車両はそれぞれ異なる種類の車両としか連結できない.また,列車に運転席を設ける関係上,列車の両端の車両は種類 **I** でなければならない.列車は車両の種類を表す文字を順につなげた文字列で表され,列車の長さはその文字列の長さであるとする.たとえば,**IOIOI** の順に車両を連結すると長さ 5 の列車を編成でき,また車両 **I** は単独で長さ 1 の列車である.車両を **OIOI** や **IOOI** といった順に並べても列車を編成することはできない.
いくつかの車両が 2 つの車庫に格納されている.それぞれの車庫の中には車両が一列に並んでいる.列車を編成するときは車庫から車両を出してきて車庫前で連結していく.車庫から出せる車両は最も車庫の入り口に近い車両のみであるが,どちらの車庫から車両を出すかの順番については自由である.
列車を編成する前に,車両を好きなだけ車庫から出して別の待機用レールに移すことができる.一度待機用レールに移した車両は今後列車を編成するために使うことはできない.また,一度列車の編成を始めるとその編成が終わるまでの間は車両を車庫から待機用レールに移すことはできない.
列車を編成するとき,車庫内の全ての車両を使い切る必要はない.すなわち,列車の編成を終えた後,車庫内に使われなかった車両が残っていても構わない.
IOI 国では鉄道に乗る人がとてもたくさんいると考えられているので,できるだけ長い列車を編成したい.
:::align{center}

図: 列車を編成している途中であり,このとき車庫にある車両を待機用レールに移すことはできない.この図は入出力例 1 に対応している.
:::
### 課題
車庫に格納された車両の情報が与えられたとき,編成できる列車の長さの最大値を求めるプログラムを作成せよ.それぞれの車庫に格納された車両の列は 2 種類の文字 **I**, **O** のみからなる文字列で表され,2 つの車庫の情報はそれぞれ長さ $M$ の文字列 $S$ および長さ $N$ の文字列 $T$ として与えられる.各文字が 1 つの車両を表し,その文字は車両の種類と同じである.文字列の 1 文字目は最も車庫の入り口に近い車両を表し,末尾の文字が車庫の最も奥にある車両を表す.
Input Format
標準入力から以下のデータを読み込め.
- 1 行目には $M, N$ が空白区切りで書かれている.
- 2 行目には文字列 $S$ が書かれている.
- 3 行目には文字列 $T$ が書かれている.
Output Format
標準出力に,編成できる列車の長さの最大値を表す整数を 1 行で出力せよ.列車が 1 つも編成できない場合は,$0$ を出力せよ.
Explanation/Hint
### 入出力例 1
$S$ によって表される車庫を車庫 **S** とし,$T$ によって表される車庫を車庫 **T** としよう.このとき,たとえば車庫 **S** から最初の 1 車両,車庫 **T** から最初の 2 車両を出して待機させた後,車庫 **S**, 車庫 **S**, 車庫 **T**, 車庫 **S**, 車庫 **S**, 車庫 **T**, 車庫 **T** の順番に車両を出せば,長さ 7 の列車 **IOIOIOI** を編成できる.
他にも,車庫 **S** から最初の 1 車両,車庫 **T** から最初の 2 車両を出して待機させた後,車庫 **T**, 車庫 **T**, 車庫 **S**, 車庫 **S**, 車庫 **T**, 車庫 **S**, 車庫 **S** の順番に車両を出すことでも長さ 7 の列車を編成できる.これより長い列車を編成することはできないので 7 を出力する.
### 入出力例 2
1 つの車両のみからなる列車 **I** も列車としての条件を満たすことに注意せよ.
### 制限
$1 \leq M \leq 2000$ 文字列 $S$ の長さ
$1 \leq N \leq 2000$ 文字列 $T$ の長さ
### 採点基準
採点用データのうち,配点の 20% 分については,$M \leq 10$, $N \leq 10$ を満たす.
採点用データのうち,配点の 50% 分については,$M \leq 50$, $N \leq 50$ を満たす.