キュゥべえはなかなか契約を結んでくれない鹿目まどかにしびれを切らせて,ソウルジェムゲームと称して佐倉杏子と美樹さやかのソウルジェムの中身 (魂) を W 列 H 段のロッカーの中に隠してしまった.そこで,まどかは杏子とさやかを助け出したい.しかし,契約を結ばずに助けるにはロッカーボックスの壁を操作して 2 人のソウルジェムの中身を,指定されたロッカーボックスに正しく移さなければならない.ロッカーはロッカーボックスが W 列 H 段に並ぶことで構成され,隣り合うロッカーボックスは壁で仕切られている.
まどかは,1 回の操作でいずれかの隣りあった 2 つのロッカーボックスの壁を取り除くか取り付けることができる.ただし,ロッカーボックスの壁を開けるには制約があり,各ロッカーボックスから隣接する上下左右の壁のうち,高々 2 枚までの壁しか同時に開けておくことはできない.ロッカーボックスには上の段から下の段に向かって重力が働いている.ソウルジェムの中身は液体と同じような動きをし,隣りあった 2 つのロッカーボックスの壁が取り除かれている時,同じ高さであれば互いに同じ量になり,違う高さであれば低い方へ移動する.すべての操作が終わった時に指定された 2 つのロッカーボックスに正しい組み合わせでソウルジェムの中身がすべて入っていればまどかの勝利となる.また,一部のロッカーボックスは穢れており,その中へソウルジェムの中身が入ってしまうと大変なことになってしまうので,そのロッカーボックスはソウルジェムの中身の移動のために使うことはできない.
最小で何度の操作を行えばまどかは 2 人を救いだすことができるかを求めよ.
入力は以下の形式で与えられる.
H\ W\\
s_{11}\ s_{12}\ … s_{1W}\\
s_{21}\ s_{22}\ … s_{2W}\\
…\\
s_{H1}\ s_{H2}\ … s_{HW}\\
H はロッカーの段数,W はロッカーの列数である.s_{ij} は上から i 段目の左から j 列目のロッカーボックスの状態を表す.杏子のソウルジェムの中身が入っているときは 'K' であり,さやかのソウルジェムの中身が入っているときは 'S' ,杏子のソウルジェムの中身を移すべきロッカーボックスであるときは 'k',さやかのソウルジェムの中身を移すべきロッカーボックスであるときは 's',穢れたロッカーボックスであるときは '#',それ以外のロッカーボックスであるときは '.' である.
CONTRACT と出力せよ.
'#', '.', 'S', 'K', 's', 'k' のいずれかである.'S' であるような i, j がちょうど 1 つだけ存在する.'K' であるような i, j がちょうど 1 つだけ存在する.'s' であるような i, j がちょうど 1 つだけ存在する.'k' であるような i, j がちょうど 1 つだけ存在する.4 4 .S.. K... .... ..sk
9
5 5 .S.K. ..#.. .###. ..#.. .k.s.
CONTRACT
8 5 S.... ####K ##... #..## #..## ##k## #...# #.s.#
19
8 5 S.... ####K ##... ##.## ##.## ##k## #...# #.s.#
CONTRACT
10 10 .......... ##......## #K......S# .......... .......... .#..##..#. ..##..##.. .......... .......... ....s.k...
22
3 3 S.s K.. ..k
CONTRACT