Keyborading
Description
给定一个r行c列的在屏幕上的“虚拟键盘”,我们需要通过“上,下,左,右,选择”5个控制键来移动屏幕上的光标来打印文本。一开始,光标在键盘的左上角,每次按方向键,光标总是跳到下一个在该方向上与当前位置不同的字符,若不存在则不移动。每次按选择键,则将光标所在位置的字符打印出来。
现在求打印给定文本(要在结尾打印换行符)的最少按键次数。
Format
Input
第一行输入r,c(1≤r,c≤50)
接下来给出一个r×c的键盘,包括大写字母,数字,横线以及星号(星号代表Enter换行)
最后一行是要打印的文本串s,s的长度不超过10000.
Output
输出打印文本(包括结尾换行符)的最少按键次数。保证一定有解。
Sample 1
Input
2 19
ABCDEFGHIJKLMNOPQZY
X*****************Y
AZAZ
Output
19
Sample 2
Input
4 7
ABCDEFG
HIJKLMN
OPQRSTU
VWXYZ**
CONTEST
Output
30
Sample 3
Input
5 20
12233445566778899000
QQWWEERRTTYYUUIIOOPP
-AASSDDFFGGHHJJKKLL*
--ZZXXCCVVBBNNMM--**
--------------------
ACM-ICPC-WORLD-FINALS-2015
Output
160
Sample 4
Input
6 4
AXYB
BBBB
KLMB
OPQB
DEFB
GHI*
AB
Output
7
Limitation
2s, 128MiB for each test case.
Source
bzoj 4111