Esistono molte implementazioni della macchina di Turing, reperibili in rete, che permettono di sperimentare.
La sintassi può presentare notevoli differenze!
La macchina ufficiale della Gara Nazionale è
- Turing Machine Simulator
Piattaforma di allenamento > Cms TuringEstensioni 2006
Alcune informazioni
- Inizialmente la macchina ufficiale della Gara Nazionale era un’applet Java, utilizzabile online oppure in locale.
- In seguito è stata sviluppata una versione Javascript che può essere utilizzata più facilmente.
- La sintassi delle quintuple è piuttosto personalizzata… consulta le istruzioni specifiche
- Scrivi il programma nell’area di testo in alto a destra
- Inserisci l’input nella casella di testo in basso a sinistra
- Passa all’esecuzione (e al debugging…)
- Velocità: si può rallentare o accelerare l’esecuzione del programma (0, 1, …, 9, 10)
- Esegui: inizia l’esecuzione del programma
- Stop: ferma l’esecuzione del programma
Avvisi ufficiali per la soluzione degli esercizi
- Se non specificato altrimenti negli esercizi, le sequenze iniziali su nastro si intendono non vuote, ovvero contenenti almeno un simbolo.
- Per numero decimale si intende un numero positivo o nullo rappresentato con le cifre 0, 1, 2, …, 9, senza zeri iniziali non significativi. Per esempio 0 e 19 sono numeri validi, mentre 0032 deve essere scritto come 32.
- Nel fornire le soluzioni, ricordarsi di pulire il nastro finale da ogni simbolo che non costituisca la risposta!
Indicazioni aggiuntive
- Lo stato iniziale è sempre 0.
- Non è specificato uno stato di arresto ufficiale, la macchina si arresta quando incontra una situazione non prevista.
- La macchina non fa distinzione tra le lettere minuscole e maiuscole.
- La testina inizia a lavorare sempre sul primo carattere a sinistra della stringa input.
Quintuple
- Le quintuple: (stato1,carattere1,stato2,carattere2,spostamento)
- Dopo la virgola si può lasciare uno spazio: (stato1, carattere1, stato2, carattere2, spostamento)
- Il carattere vuoto (spazio) viene rappresentato con – (il segno meno)
- Gli spostamenti sono
- > , destra
- <, sinistra
- –, fermo
- Il segno meno indica il carattere bianco e indica anche lo spostamento nullo.