eolymp
bolt
Попробуйте наш новый интерфейс для отправки задач
Задачи

Stack Maze

Stack Maze

There is a maze which can be described as a \textbf{W}×\textbf{H} grid. The upper-left cell is denoted as (\textbf{1}, \textbf{1}), and the lower-right cell is (\textbf{W}, \textbf{H}). You are now at the cell (\textbf{1}, \textbf{1}) and have to go to the cell (\textbf{W}, \textbf{H}). However, you can only move to the right adjacent cell or to the lower adjacent cell. The following gure is an example of a maze. \includegraphics{https://static.e-olymp.com/content/68/68fc37835f86dd1a618a705047b09d98064588cd.jpg} In the maze, some cells are free (denoted by '\textbf{.}') and some cells are occupied by rocks (denoted by '\textbf{#}'), where you cannot enter. Also there are jewels (denoted by lowercase alphabets) in some of the free cells and holes to place jewels (denoted by uppercase alphabets). Different alphabets correspond to different types of jewels, i.e. a cell denoted by '\textbf{a}' contains a jewel of type \textbf{A}, and a cell denoted by '\textbf{A}' contains a hole to place a jewel of type \textbf{A}. It is said that, when we place a jewel to a corresponding hole, something happy will happen. At the cells with jewels, you can choose whether you pick a jewel or not. Similarly, at the cells with holes, you can choose whether you place a jewel you have or not. Initially you do not have any jewels. You have a very big bag, so you can bring arbitrarily many jewels. However, your bag is a stack, that is, you can only place the jewel that you picked up last. On the way from cell (\textbf{1}, \textbf{1}) to cell (\textbf{W}, \textbf{H}), how many jewels can you place to correct holes? \InputFile The input contains a sequence of datasets. The end of the input is indicated by a line containing two zeroes. Each dataset is formatted as follows. \textbf{H W} \textbf{C_11 C_12 ... C_1W} \textbf{C_21 C_22 ... C_2W} \textbf{...} \textbf{C_H1 C_H2 ... C_HW} Here, \textbf{H} and \textbf{W} are the height and width of the grid. You may assume \textbf{1} ≤ \textbf{W}, \textbf{H} ≤ \textbf{50}. The rest of the datasets consists of \textbf{H} lines, each of which is composed of \textbf{W} letters. Each letter \textbf{C_ij} speci es the type of the cell (\textbf{i}, \textbf{j}) as described before. It is guaranteed that \textbf{C_11} and \textbf{C_WH} are never '\textbf{#}'. You may also assume that each lowercase or uppercase alphabet appear at most \textbf{10} times in each dataset. \OutputFile For each dataset, output the maximum number of jewels that you can place to corresponding holes. If you cannot reach the cell (\textbf{W}, \textbf{H}), output \textbf{-1}.
Лимит времени 2 секунды
Лимит использования памяти 256 MiB
Входные данные #1
3 3
ac#
b#C
.BA
3 3
aaZ
a#Z
aZZ
3 3
..#
.#.
#..
1 50
abcdefghijklmnopqrstuvwxyYXWVUTSRQPONMLKJIHGFEDCBA
1 50
aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyY
1 50
abcdefghijklmnopqrstuvwxyABCDEFGHIJKLMNOPQRSTUVWXY
1 50
aaaaaaaaaabbbbbbbbbbcccccCCCCCBBBBBBBBBBAAAAAAAAAA
10 10
...#......
a###.#####
.bc...A...
##.#C#d#.#
.#B#.#.###
.#...#e.D.
.#A..###.#
..e.c#..E.
####d###.#
##E...D.C.
0 0
Выходные данные #1
2
0
-1
25
25
1
25
4
Источник JAG Practice Contest for ACM-ICPC Asia Regional 2012, AtCoder, 2012/11/04