Problem C
Laserschack
Fredrik och Abdullah spelar ett parti Laserschack mot varandra. Spelet spelas på ett rutnät, och går ut på att skjuta en laserstråle på motståndarens kung. Abdullah har en attackpjäs som när man trycker på en knapp skjuter ut laser i alla fyra riktningar (upp, ned, höger och vänster), markerad med A i rutnätet. Fredriks kung är markerad med K. Det finns också spegelpjäser i rutnätet, markerade med o. När en laser träffar en spegelpjäs studsar strålen ut i all fyra riktningar.
Spelet har just hamnat i en position där Abdullah kommer vinna om han bara trycker på knappen för att skjuta lasern. För att stoppa Abdullah från att vinna har nu Fredrik lagt ut rökbomber på planen, markerade med R. Röken stoppar laserstrålar från att färdas genom den rutan. Varje sekund sprider sig röken till alla dom fyra angränsande rutorna. Om attackpjäsen eller kungen är i rök kan inte Abdullah vinna.
Hur många sekunder tar det innan Abdullah inte längre vinner genom att trycka på knappen? Alltså, hur många sekunder tar det tills att röken spridit sig så att lasern inte längre når kungen från attackpjäsen? Det är garanterat att spelet ursprungligen är i en position där lasern når kungen från attackpjäsen utan att gå genom någon rök.
Indata
Den första raden innehåller två heltal $R$ och $C$ ($1\le R, 1 \le C, R\times C \le 40 000$) , antalet rader och kolumner i rutnätet som utgör spelplanen.
De följande $R$ raderna utgör en beskrivning av hur spelplanen ser ut. Den $i$:te av dessa rader innehåller $C$ tecken som beskriver hur den $i$:te raden ser ut. Varje tecken är något av följande:
-
. för en tom ruta
-
o för en spegelpjäs
-
R för en rökbomb
-
A för attackpjäsen
-
K för kungen
Det garanteras att A och K förekommer exakt en gång vardera, att R förekommer minst en gång, och att laserstrålen når fram till kungen från attackpjäsen från början.
Utdata
Skriv ut ett positivt heltal – antal sekunder det tar tills lasern inte längre når kungen.
Poängsättning
Din lösning kommer att testas på en mängd testfallsgrupper. För att få poäng för en grupp så måste du klara alla testfall i gruppen.
Grupp |
Poängvärde |
Gränser |
$1$ |
$10$ |
$R=1$ |
$2$ |
$20$ |
Det finns exakt ett R på brädet. |
$3$ |
$20$ |
Ingen ruta är tom (.) |
$4$ |
$20$ |
$R\times C \leq 400$ |
$5$ |
$30$ |
Inga ytterligare begränsningar. |
Förklaring av Exempelfall
Så här ser rökens spridning ut för varje exempelfall i sista sekunden där lasern fortfarande når kungen.
Exempelfall
Sample Input 1 | Sample Output 1 |
---|---|
3 3 .Ao R.. .Ko |
2 |
Sample Input 2 | Sample Output 2 |
---|---|
5 8 A......o ..K.o... o....o.o ..o..o.. R...o..o |
4 |
Sample Input 3 | Sample Output 3 |
---|---|
10 9 oo.o.oRR. .K.oo..R. ....oo..R ..R...... ..R...... A....o.o. ...R..... .....o.o. ......... o....o..R |
3 |