Light Road
2 ≤ N, M ≤ 100
There is an evil creature in a square on N-by-M grid (), and you want to kill it using a laser generator located in a different square. Since the location and direction of the laser generator are fixed, you may need to use several mirrors to reflect laser beams. There are some obstacles on the grid and you have a limited number of mirrors. Please find out whether it is possible to kill the creature, and if possible, find the minimum number of mirrors.
There are two types of single-sided mirrors; type P mirrors can be placed at the angle of 45 or 225 degrees from east-west direction, and type Q mirrors can be placed with at the angle of 135 or 315 degrees. For example, four mirrors are located properly, laser go through like the following.
A
A
0 ≤ A ≤ 10
Note that mirrors are single-sided, and thus back side (the side with cross in the above picture) is not reflective. You have type P mirrors, and also type Q mirrors (). Although you cannot put mirrors onto the squares with the creature or the laser generator, laser beam can pass through the square. Evil creature is killed if the laser reaches the square it is in.
Input
Each test case consists of several lines.
N
M
A
N
M
The first line contains three integers, , , and . Each of the following lines contains characters, and represents the grid information. '#', '.', 'S', 'G' indicates obstacle, empty square, the location of the laser generator, and the location of the evil creature, respectively. The first line shows the information in northernmost squares and the last line shows the information in southernmost squares. You can assume that there is exactly one laser generator and exactly one creature, and the laser generator emits laser beam always toward the south.
Output
Output the minimum number of mirrors used if you can kill creature, or -1 otherwise.