2514. Ninja Legend

单点时限: 10.0 sec

内存限制: 256 MB

Ninjas are professional spies in the Middle Age of Japan. They have been popular in movies and games as they have been described with extraordinary physical abilities and unrealistic abilities.

You are absorbed in one of ninja games, Ninja Legend. In this game, you control in an exceptionally talented ninja named Master Ninja and accomplish various missions. In one of the missions, the ninja intrudes into a mansion and aims to steal as many gold pieces as possible. It is not easy to be done because there are many pitfalls to evade him. Once he falls into a pitfall, all he can do will be just to wait for being caught by the owner of this mansion. This definitely means failure of the mission. Thus, you must control the ninja with a good strategy.

The inside of mansion is represented by a grid map as illustrated below. Master Ninja enters at and exits from the entrance. He can move in the four directions to the floor cells. He can pick up gold blocks when he moves to the cells where they are placed, but it is also allowed to pick up them in the later visit of those cells or even to give up them.

The ninja has a couple of special abilities for dealing with the pitfalls. He has two moving modes: normal mode and dash mode. He is initially in the normal mode. He gets into the dash mode when he moves in the same direction by two cells in a row without picking up gold blocks. He gets back to the normal mode when he changes the direction, picks up a gold block, or runs on a wall as mentioned later. He is able to jump over a pitfall, or in the dash mode he can jump over two pitfalls in his dashing direction. In addition, when he is in the dash mode, he can run on a wall to pass over up to four pitfalls in his dashing direction. For his running, there must be consecutive wall cells adjacent to the passing cells including the departure and arrival floor cells. Note that he gets back to the normal mode when he runs on a wall as mentioned previously.

In the figure up, the figure 2 shows how the ninja runs on a wall, and the figure 3 illustrates a case in which he cannot skip over pitfalls by running on a wall.

You want to know the maximum number of gold blocks the ninja can get, and the minimum cost to get those gold blocks. So you have decided to write a program for it as a programmer. Here, move of the ninja from a cell to its adjacent cell is considered to take one unit of cost.

输入格式

The input consists of multiple datasets.

The first line of each dataset contains two integers H (3 ≤ H ≤ 60) and W (3 ≤ W ≤ 80). H and W indicate the height and width of the mansion. The following H lines represent the map of the mansion. Each of these lines consists of W characters. Each character is one of the following: ‘%’ (entrance), ‘#’ (wall), ‘.’ (floor), ‘^’ (pitfall), ‘*’ (floor with a gold block).

You can assume that the number of gold blocks are less than or equal to 15 and every map is surrounded by wall cells.

The end of the input indicated with a line containing two zeros.

输出格式

For each dataset, output the maximum number of gold blocks and the minimum cost in one line. Output two zeros instead if the ninja cannot get any gold blocks. No other characters should be contained in the output.

样例

Input
6 23
#######################
#%.^.^#################
#^^^^^######^^^^^^^^^^#
#^^^...^^^^...^^*^^..*#
#^^^^^^^^^^^^^^^^^^^^^#
#######################
5 16
################
#^^^^^^^^^^^^^^#
#*..^^^.%.^^..*#
#^^#####^^^^^^^#
################
0 0
Output
1 44
2 28

0 人解决,1 人已尝试。

0 份提交通过,共有 2 份提交。

9.9 EMB 奖励。

创建: 15 年,8 月前.

修改: 7 年,2 月前.

最后提交: 2 月前.

来源: N/A

题目标签