Regole generali

Il tempo per portare a termine la prova è di tre ore.
La prova consta un unico esercizio, fare in modo che la classe principale (che contiene il main) dell'esercizio si chiami Esercizio.
Iniziare ogni file sorgente con un commento che contiene il cognome e il nome del candidato (nell'ordine e usando opportunamente maiuscole e minuscole) e il suo numero di matricola (Es: //Bianchi Mario 0000156786).

È permesso l'uso di fogli bianchi per appunti; non è permesso l'uso di alcun tipo di materiale di consultazione tranne la documentazione in linea accedibile attraverso l'ambiente preconfigurato (usando il plugin InfoViewer attivabile con il pulsante nel bordo destro).

Per la compilazione è possibile utilizzare i plugin JCompile e RunIt (accedibili dal menu Plugins), ricordarsi di salvare il file prima della compilazione.

L'elaborato consegnato verrà corretto solo se compilabile senza errori; tutti i file sorgenti vanno salvati nella directory di default presentata dal programma.

La modularizzazione (suddivisione in classi/metodi) e l'uso opportuno di commenti che rendano comprensibile l'elaborato sono parametri utilizzati in sede di valutazione. Anche nel caso di uso di più classi fare in modo di consegnare un unico sorgente (a tal fine si rammenta che un file sorgente può contentere un'unica classe pubblica ma può contenerne altre non pubbliche).

Esercizio: catena di parole

Scrivere un programma che accetti in input da riga di comando il nome di un file di testo e un valore numerico n.

Il file di testo deve contenere una lista di parole, una su ogni linea, da usare come dizionario.

Il programma deve visualizzare in output la più lunga catena di parole ottenibile usando parole del dizionario.

Una catena di parole è una sequenza di parole in cui ogni parola, esclusa la prima, inizia con le stesse n lettere con cui si conclude la parola precedente. Il valore n corrisponde a quello acquisito da linea di comando.

Esempio:

Lanciando il programma con java Esercizio dizionario.txt 2, dove il file dizionario.txt contiene:

mare
roma
casa
remo

si potrà ottenere in output:

roma
mare
remo