Sono sicuro che tutti hanno visto prima che le tazze possono essere impilate in piramidi (e altre forme):
A
A A A
A A A A A
A A A A A A A A
Sì, A
è sicuramente un personaggio adeguato per rappresentare una tazza.
È possibile aggiungere nuove tazze a terra, a destra della struttura o in cima a due tazze adiacenti. Ecco di nuovo la struttura sopra, ma tutti i punti disponibili per le nuove tazze sono contrassegnati con _
:
_ A
A A A
A _ _ A A A A
A A A A A A A A _ _ _
Diciamo che vogliamo costruire un robot in grado di assemblare queste pile di tazze. Il robot comprenderà due semplici istruzioni per manipolare tale struttura:
a
: Aggiungi una nuova tazza nel primo punto disponibile nell'ordine di lettura da sinistra a destra (ovvero, scansiona le righe dall'alto verso il basso, da sinistra a destra fino a trovare un punto disponibile, quindi posiziona lì la tazza). L'esempio sopra sarebbe diventato:A A A A A A A A A A A A A A A A A A
r
: Rimuovere la prima tazza nell'ordine di lettura da sinistra a destra. L'esempio sopra sarebbe diventato:A A A A A A A A A A A A A A A A
Si scopre che qualsiasi struttura può essere costruita da zero usando solo queste due operazioni. Per esempio
A
A A A
A A A A A
Può essere costruito con la sequenza di istruzioni
aaaaaaaaaaaarrrrraa
L'esempio più grande sopra può essere creato usando
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaarrrrrrrrrrrrrrrrrraaaaaaarr
Eccone uno ancora più grande:
A
A A A
A A A A A A A
A A A A A A A A A A A A
A A A A A A A A A A A A A A A
che può essere costruito con
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrraaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaarrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrraaaaaaaaaaaaaaaaaaarrrrrrrrrrrrrrraaaaaaaaaaaaaarrrrrrrrrrraaaaaaaa
Nota: se i punti sul terreno vengono liberati dalle istruzioni di rimozione, verranno riutilizzati prima di posizionare le tazze a destra di tutte le tazze esistenti. Per esempio
aaaarrra
cederà
A A
non
A A
Puoi pensare al terreno come se fosse in cima a una fila semi-infinita di tazze.
La sfida
Data una struttura di tazze impilate, restituisce una sequenza che rappresenta le istruzioni per costruire questa struttura. Il tuo punteggio principale è la somma dei numeri di istruzioni per i casi di test forniti in fondo. In caso di pareggio (che è probabile, perché sono convinto che sia possibile una soluzione ottimale efficiente), vince la soluzione più breve.
Ecco alcuni dettagli sulle regole:
- Si può presumere che non ci siano spazi iniziali nella riga inferiore dell'input, quindi si deve sempre usare il punto più a sinistra per una tazza.
- Puoi assumere qualsiasi ragionevole quantità di spazi finali (nessuno spazio, uno spazio, riempito con un rettangolo, riempito con un rettangolo con un singolo spazio finale).
- Opzionalmente, è possibile aspettarsi che l'input termini in una sola nuova riga finale.
- Puoi scegliere due caratteri ASCII stampabili distinti (da 0x20 a 0x7E, inclusi) invece di
A
e spazi (le regole relative agli spazi vengono quindi trasferite al personaggio scelto). - L'output deve contenere solo due caratteri distinti che rappresentano le operazioni (è possibile scegliere altri caratteri oltre a
a
er
). Se lo si desidera, è possibile stampare una nuova riga finale. - Il tuo codice deve essere in grado di risolvere uno dei casi di test di seguito in meno di un minuto su un PC desktop ragionevole (se impiegherò due minuti al mio, ti darò il beneficio del dubbio, ma se impiegherò dieci ho vinto 't - credo che sia possibile un algoritmo ottimale che risolva qualcuno di loro in meno di un secondo).
- Non è necessario ottimizzare il codice per i singoli casi di test (ad es. Codificandoli a piacere). Se sospetto che qualcuno lo faccia, mi riservo il diritto di modificare i casi di test.
Puoi usare questo script CJam per l'operazione inversa: ci vorranno una serie di istruzioni per la costruzione e stamperanno la pila di tazze risultante. (Grazie a Dennis per aver riscritto lo snippet e averlo notevolmente accelerato.)
Sp3000 ha anche gentilmente fornito questo script Python alternativo per lo stesso scopo.
Casi test
Dopo ogni caso di test, c'è un numero che indica il numero ottimale di istruzioni secondo la risposta di Ell.
A
A A
A A A
A A A A
A A A A A
A A A A A A
A A A A A A A
A A A A A A A A
A A A A A A A A A
A A A A A A A A A A
A A A A A A A A A A A
A A A A A A A A A A A A
A A A A A A A A A A A A A
A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
820
A
A A
A A A
A A A A
A A A A A
A A A A A A
A A A A A A A
A A A A A A A A
A A A A A A A A A A
A A A A A A A A A A A A
A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
1946
A
A A
A A A
A A A A
A A A A A
A A A A A A
A A A A A A A
A A A A A A A A
A A A A A A A A A A
A A A A A A A A A A A A
A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
2252
A A
A A A A
A A A A A A
A A A A A A A A
A A A A A A A A A A
A A A A A A A A A A A A
A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
9958
A A
A A A A
A A A A A A
A A A A A A A A
A A A A A A A A A A
A A A A A A A A A A A A
A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
5540
A A A A A A A A A A A A A A A A A A A A
10280
A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
10320
A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
5794
A
A A
A A A
A A A A A
A A A A A A A
A A A A A A A A A A
A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
3297
A A
A A A
A A A A
A A A A A
A A A A A A
A A A A A A A
A A A A A A A A
A A A A A A A A A
A A A A A A A A A A A
A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
4081
A
A A A A
A A A A A A A A A
A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
4475
A
A A A A A A A A
A A A A A A A A A A A A A A A A A A A
A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A
5752
Ciò significa che il miglior punteggio possibile è 64.515 istruzioni.