Problem F
Chalmers mörka källare
Languages
en
sv
Du är på väg till finalen i Programmeringsolympiaden. Dessvärre har du gått vilse i Chalmers mörka källare. Ditt lokalsinne är inte på topp, och det hjälper inte att källaren är utformad på ett mycket underligt sätt.
Källaren består av $2 \leq N \leq 1000$ våningar. På bottenplan finns ett enda stort rum. Alla andra rum har ett rum direkt ovanför sig. När du går ner en våning blir rummen hälften så stora. Under varje rum $i$ finns upp till två rum $l_ i$ och $r_ i$ som är precis hälften så stora. Det är också möjligt att bara ett av $l_ i$ och $r_ i$ finns, eller att inget av dem finns. Du kan ta dig mellan två rum genom en dörr om de ligger precis bredvid varandra, eller via en trappa om det ena ligger direkt över det andra. Du kan ta dig till alla rum från bottenplan utan att gå igenom dörrar. Du befinner dig just nu i något rum i källaren, och du vet att rummet där finalen hålls också ligger i källaren.
En väg är en sekvens av steg till närliggande rum. För någon väg $v$ från rummet du befinner dig i till rummet finalen hålls i, låt $A_ v$ vara antalet gånger du går genom en dörr, och $B_ v$ antalet gånger du går upp eller ner för en trappa. Vägens längd definieras som summan $L_ v = A_ v + B_ v$. Du vill nu ta dig till finalen. Till din hjälp har du appen Campus Maps. Campus Maps är programmerad för att hitta längden på den väg till din destination, där antalet trappor du behöver gå upp eller ned för minimeras. Av alla möjliga vägar $v$ till rummet där finalen hålls kommer appen att hitta de som minimerar värdet på $B_ v$. Av alla dessa vägar kommer appen sedan välja den som minimerar värdet på $L_ v$. Den kommer sedan ge dig värdet $L_ v$, längden på denna vägen.
Eftersom appen tar väldigt lång tid att ladda så hinner du kolla i den som mest $500$ gånger. Du hinner inte heller passera fler än $5000$ rum.
(1.a) |
() |
(1.b) |
() |
Interaktion
Först och främst får du information om rummet du befinner dig i. Detta ges i form av en binär sträng av längd fem, där varje tecken är “1” om du kan gå i en viss riktning och “0” annars. I ordning säger strängens tecknen om du kan gå uppåt, åt höger, nedåt åt höger, nedåt åt vänster, och åt vänster. Så strängen 01001 innebär att det finns ett rum till ditt vänster och ett till ditt höger, men inga andra närliggande rum.
Du får sedan välja om du vill gå till ett annat rum, eller använda appen Campus Maps. För att gå till ett annat rum skriver du någon av strängarna “up”, “right”, “downright”, “downleft” eller “left”. Du får då information om det nya rum du befinner dig i, enligt samma format som ovan.
För att använda appen skriver du “app”. Appen beräknar då värdet på $L_ v$ enligt beskrivningen ovan. Eftersom appen är väldigt känslig för Integer Overflows, kommer den krasha om denna längd överstiger $10^9$. Isåfall skriver appen ut $-1$. Annars skrivs längden på vägen ut. När du är framme ska du skriva ut “here”, och ditt program måste då avslutas.
Se till att flusha outputen efter varje query, annars kan du få Time Limit Exceeded. I C++ kan detta göras med exempelvis cout << flush; eller fflush(stdout);, i Python med stdout.flush() och i Java med System.out.flush();.
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$ |
$5$ |
$N = 2$ |
$2$ |
$10$ |
$N \leq 10$ |
$3$ |
$10$ |
$N \leq 250$ |
$4$ |
$16$ |
Varje rum som inte ligger längst ner i källaren har två rum under sig. |
$5$ |
$13$ |
$N \leq 500$ |
$6$ |
$21$ |
$N \leq 950$ |
$7$ |
$25$ |
$N \leq 1000$ |
Read | Sample Interaction 1 | Write |
---|
11110
app
4
up
11110
right
10101
app
2
downright
10010
downleft
10000
app
0
here
Read | Sample Interaction 2 | Write |
---|
10001
app
6
up
10111
app
4
left
11111
left
11111
left
11110
downright
11001
here