Testo 8
Testo 8
18/07/2023
Istruzioni
Risolvere il seguente esercizio implementando un programma in un singolo
file .cpp, completo di funzione main. Si presti particolare attenzione alla
formattazione dell’input e dell’output, e alla complessità target indicata per
ciascuna funzionalità. Nel caso la complessità target non sia specificata,
si richiede che sia la migliore possibile. La lettura dell’input e la scrittu-
ra dell’output DEVONO essere effettuate tramite gli stream cin e cout
rispettivamente. La correzione avverrà prima in maniera automatica in-
viando il file .cpp al server indicato in aula. Quest’ultimo esegue dei test
confrontando l’output prodotto dalla vostra soluzione con l’output atteso.
In caso la verifica abbia esito positivo sarà possibile consegnare il compi-
to, il quale verrà valuato dai docenti in termini di complessità. Si ricorda
che è possibile testare la correttezza del vostro programma in locale su un
sottoinsieme dei input/output utilizzati nella seguente maniera. I file di
input e output per i test sono nominati secondo lo schema: input0.txt
output0.txt input1.txt output1.txt ... Per effettuare le vostre prove
potete utilizzare il comando del terminale per la redirezione dell’input. Ad
esempio
effettua il test del vostro codice sui dati contenuti nel primo file di input,
assumendo che compilato contenga la compilazione della vostra soluzione e
che si trovi nella vostra home directory. Dovete aspettarvi che l’output coin-
cida con quello contenuto nel file output0.txt. Per effettuare un controllo
automatico sul primo file input input0.txt potete eseguire la sequenza di
comandi
1
Esercizio
Si consideri un sistema per la gestione di alberi binari di ricerca (ABR)
aventi etichette intere. A ciascuno nodo é associato un colore rappresentato
tramite un carattere alfanumerico. Siano date le seguenti definizioni:
Un nodo si dice accerchiato se è figlio di un padre con colore c, ed ha
due figli con colore c.
Scrivere un programma che:
Esempio
Input
10
10 v
5 v
3 r
1 v
7 v
4 v
8 v
15 v
20 v
40 g
Output