Torna indietro   Hardware Upgrade Forum > Software > Programmazione

OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
Abbiamo partecipato all'OVHcloud Summit 2025, conferenza annuale in cui l'azienda francese presenta le sue ultime novità. Abbiamo parlato di cloud pubblico e privato, d'intelligenza artificiale, di computer quantistici e di sovranità. Che forse, però, dovremmo chiamare solo "sicurezza"
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Abbiamo potuto mettere le mani in anteprima sul nuovo monitor MSI dedicato ai giocatori: un mostro che adotta un pannello QD-OLED da 26,5 pollici con risoluzione 2560 x 1440 pixel, frequenza di aggiornamento fino a 500 Hz e tempo di risposta di 0,03 ms GtG
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI aggiorna la sua linea di droni ultraleggeri con Neo 2, un quadricottero da 160 grammi che mantiene la compattezza del predecessore ma introduce una stabilizzazione meccanica a due assi, sensori omnidirezionali e un sistema LiDAR
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-01-2007, 19:01   #1
EnZiMa
Senior Member
 
L'Avatar di EnZiMa
 
Iscritto dal: May 2001
Messaggi: 191
[JAVA] esercizio catena di parole

Salve a tutti, devo fare per l'uni questo progettino...

-----

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

-----
ecco quello che ho fatto:
Codice:
import java.util.ArrayList;
public class Esercizio{
	private int num=2;
ArrayList<String> parole = new ArrayList<String>();	//Creo l'arrayList parole del dizionario
ArrayList<String> parole2 = new ArrayList<String>();


private void inserisci(){
parole.add("mare");
parole.add("roma");
parole.add("casa");
parole.add("remo");
}

	private void stampa(){
		
		for (int i=0 ; i< parole2.size() ; i++) {
			
			System.out.println(parole2.get(i).toString()); 
		}
	}
	

	
	private void scandisci(){
	parole2.add(parole.get(1));
	int count =0;
	String fine = finisceCon(parole.get(1).toString(),num);
	//while(count<parole.size()){
		
		for (int i=0 ; i< parole.size() ; i++) {
		
			for (int j=0 ; j< parole.size() ; j++) {
		
				String inizio = iniziaCon(parole.get(j).toString(),num);
				if(fine.equals(inizio)){
					parole2.add(parole.get(j));
					parole.remove(j);
				}
				//else break;
		}
		count++;
		//fine = finisceCon(parole.get(i).toString(),num);
	//}	
	}
	}
	
	
private String finisceCon(String parola, int num){
	int lettere=parola.length();
	int start=lettere-num;
	String nuovaparola=parola.substring(start,lettere);
	return nuovaparola;
}


private String iniziaCon(String parola, int num){

	String nuovaparola=parola.substring(0,num);
	return nuovaparola;
}


	public static void main (String[]args){
	
	Esercizio Catena = new Esercizio();
	Catena.inserisci();
	Catena.scandisci();
	Catena.stampa();



}
}
la soluzione migliore sarebbe farlo in modo ricorsivo ma a me non viene nemmeno completo iterativo!!!

Grazie
__________________
Project HTPC: work in progress!
EnZiMa è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone L'IA "seria" di Appian è divers...
Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
AWS Transform si evolve: agenti IA per m...
I social network hanno stancato gli ital...
Star Citizen supera i 900 milioni di dol...
Netflix ha eliminato la funzione Cast pe...
L'IA è una bolla e scoppier&agrav...
Un rapporto collega i data center di Ama...
Troppa concorrenza per Cherry (quella de...
Entro il 2035 la Cina vuole costruire de...
Tineco in super sconto: ultimo giorno di...
La Cina creerà una costellazione ...
I veicoli elettrici emettono radiazioni ...
Stai per acquistare una PS5? Attento al ...
iPhone 17 Pro Max finalmente disponibile...
Apple, Sony, Bose, Beats, Sennheiser, CM...
Arriva il Raspberry Pi 5 da 1 GB, ma por...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 06:28.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v