Problem B
Pokémon Ice Maze
You are hired as a level designer for the next Pokémon series, with games called Ice and Fire. For the first of these two games, players have to get through a maze in an icy cave. The cave is represented as a grid, with each square of the grid being either ice, gravel or an obstacle.
The player will start at a square, and then make a number of moves, each move represented by one of the four cardinal directions. The maze behaves in the following way. Assume that the square the player is trying to move into is an obstacle. In this case, the player does not move. If the square the player is moving into is gravel, the player successfully moves to the square and will stand still on the square. If the square is ice however, the player will first be transferred into that square, and then repeat the procedure again in the same direction. This means the player will glide on the ice until either colliding with an obstacle or reaching a square filled with gravel. Gliding on ice counts only as one move.
You have almost finished your level design. In the maze, there is a goal square that you wish to reach. You still have to choose a square to be the starting point of the player. Since you do not want the level to be too easy, you want to make sure the number of moves needed to get from the starting point to the goal is sufficiently high.
Can you compute the minimum number of moves needed to get from each point in the maze to the goal? Note that move may result in the player traveling multiple squares if gliding on the ice.
Input
The first line of the input contains the two integers
The next
-
a period (.) represents a gravel square
-
a pound sign (#) represents an obstacle
-
an underscore (_) represents an ice square
-
an M (M) represents the goal in the maze, which is also covered in gravel
The edges of the maze are always surrounded by obstacle squares.
Output
Output
If it is not possible to reach the target from a square,
output
Sample Input 1 | Sample Output 1 |
---|---|
5 6 ##### #...# #_### #_M.# #__.# ##### |
-1 -1 -1 -1 -1 -1 4 5 6 -1 -1 4 -1 -1 -1 -1 1 0 1 -1 -1 3 1 2 -1 -1 -1 -1 -1 -1 |
Sample Input 2 | Sample Output 2 |
---|---|
5 6 ##### ##__# ##__# ##M_# ##_## ##### |
-1 -1 -1 -1 -1 -1 -1 1 2 -1 -1 -1 1 2 -1 -1 -1 0 1 -1 -1 -1 1 -1 -1 -1 -1 -1 -1 -1 |