#icpc2014summerday4b. [icpc2014summer_day4_b]不審者
[icpc2014summer_day4_b]不審者
MathJax.Hub.Config({ tex2jax: { inlineMath: [[""], ["\\(","\\)"]], processEscapes: true }}); blockquote { font-family: Menlo, Monaco, "Courier New", monospace; color: #333333; display: block; padding: 8.5px; margin: 0 0 9px; font-size: 12px; line-height: 18px; background-color: #f5f5f5; border: 1px solid #ccc; border: 1px solid rgba(0, 0, 0, 0.15); -webkit-border-radius: 4px; -moz-border-radius: 4px; border-radius: 4px; white-space: pre; white-space: pre-wrap; word-break: break-all; word-wrap: break-word; }
Problem Statement
AさんとB君は, の長方形のマス目状の地域に住んでいる.各マス目は道か壁か家のどれかである. この地域は,道が複雑で入り組んでいるので痴漢被害がよく起こることで有名であるため,この地域と外部との境界は全て壁で囲まれており,隔離されている.
B君はなんとなく気が向いたので,Aさんの家を眺めに行くことにした.しかし,不幸なことにB君は明らかに怪しい顔をしているので,Aさんの家に行く途中に少しでも痴漢の疑いがあるような行動を取ったらすぐに捕まってしまうだろう.特に,右手を壁から離して歩くことは絶対にやってはならない.B君は,一瞬たりとも右手を離すことなく,Aさんの家に辿り着くことが出来るだろうか?
B君はつねに上下左右いずれかの方向を向いていて,B君の右手が届く範囲はB君の向いている方向に対して正面,斜め右前,右,斜め右後ろの4マスのみである. B君は,次のいずれかの行動を繰り返す.ただし,これらを同時に行うことは出来ない.
- 前方に壁がない場合,1マス進む.
- 向いている方向を90度右に変える.
- 向いている方向を90度左に変える.
- 右手が接するマスを変える.ただし,この時にB君は右手を離すことが出来ないので,変更前のマスと変更後のマスの間には共通した点を持っていなくてはならない.
Input
入力は以下の形式で与えられる.
:
:
() は, 文字の文字列で各文字は次を表す.
- "^","v","<",">"はB君の最初の位置と最初に向いている方向(上下左右の向き)を表す.
- "." は,何もないマスである.B君は,このマスの上を移動することができる.
- "#" は,壁を表す.壁の上を移動することは出来ない.
- "G" はAさんの家の位置を表す.B君は,Aさんの家にたどり着くまで移動を繰り返す.
Constraints
- 入力には,文字 "^","v","<",">" のうちいずれかが必ず一つのみ現れる.
- 同様に,入力には,文字 "G" が必ず一つのみ現れる.
- 初期状態では,B君が向いている方向から右の壁にB君の右手が接している.
Output
一度も右手を離さずにAさんの家に辿り着くことが出来る場合には,Aさんの家にたどり着くまでに通った異なるマスの数の最小値を出力せよ. Aさんの家に辿り着くことが出来ない場合には,-1を出力せよ.
Sample Input 1
3 3
G##
.#.
.<.```
### Output for the Sample Input 1
```plain
4```
* * *
### Sample Input 2
```plain
3 3
G##
.#.
.>.```
### Output for the Sample Input 2
```plain
6```
* * *
### Sample Input 3
```plain
3 3
...
.G.
.>.```
### Output for the Sample Input 3
```plain
-1```
* * *
### Sample Input 4
```plain
4 4
....
.#.G
...#
^#..```
### Output for the Sample Input 4
```plain
8```
* * *