Torna indietro   Hardware Upgrade Forum > Software > Programmazione

MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
Wireless 2.4 GHz, Bluetooth 5.4, cancellazione attiva del rumore, design pieghevole e un'autonomia che mette in imbarazzo prodotti che costano il doppio. Le Maestro 500 non eccellono in nulla, ma offrono tutto. E a questo prezzo è difficile chiedere di più
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
Dopo anni di attesa e una lunga fase di sviluppo, Noctua entra nel mercato dei dissipatori a liquido AIO con la nuova serie NL-LC1. Forte dell'esperienza maturata nel raffreddamento ad aria, l'azienda austriaca promette di portare la propria filosofia fatta di qualità costruttiva, attenzione ai dettagli e silenziosità anche in questo segmento. Abbiamo provato il nuovo sistema per scoprire se riesce a distinguersi in un mercato ormai molto competitivo.
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Arrivato sul mercato italiano a fine marzo, la serie Boox Go 10.3 (Gen II) offre Android 15, penna da 4096 livelli e retroilluminazione opzionale (nel modello da noi provato, Lumi, presente). La serie si compone di due tablet ePaper che fanno da e-reader, blocco note digitale e persino browser, tutto a un prezzo che fa dimenticare i prodotti di brand più blasonati
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-11-2005, 12:38   #1
BreV&
Senior Member
 
L'Avatar di BreV&
 
Iscritto dal: Mar 2004
Città: Pogliano Milanese
Messaggi: 665
[JAVA] Il problema dell'LCS

Salve a tutti, questo è il mio primo post in questa sezione...
...chissà quanti ne avete visti come me...
...venerdì si consegna e non riesco a finire il programma

Dunque, il problema è il classico LCS (Longest Common Subsequence), però al posto della classica ricostruzione della soluzione ottima, io devo stampare TUTTE le soluioni ottime...
...e non so da dove cominciare...

Codice:
import java.io.*;

public class Lcs
{
 public void stampaMat(int[][] mat, int n, int m)
 {
 	for(int i=1; i<n; i++)
 	{
 		for(int j=1; j<m; j++)
 		        System.out.print(mat[i][j]);
 		System.out.println();
  	}
  	System.out.println();
 }

 public void stampaMat(char[][] mat, int n, int m)
 {
 	for(int i=1; i<n; i++)
 	{
 		for(int j=1; j<m; j++)
 		        System.out.print(mat[i][j]);
 		System.out.println();
  	}
  	System.out.println();
 }

 public int[][] minit(int n, int m) //matrice init
 {
 	int[][] mat = new int[n][m];
 	for (int i=0; i<n; i++)
            for (int j=0; j<m; j++)
                mat[i][j]=0;
 	return mat;
 }
 public char[][] sinit(int n, int m) //soluzione init
 {
 	// [D]iagonal [L]eft [u]p
 	char[][] sol = new char[n][m];
 	for (int i=0; i<n; i++)
            for (int j=0; j<m; j++)
                sol[i][j]='X';
 	return sol;
 }


 public char[][] fill(int[][] mat, char[][] sol,String a, String b, int n, int m)
 {
 	for (int i=1; i<n; i++)
 	{
 		for(int j=1; j<m; j++)
 		{
 			if (a.charAt(i-1) == b.charAt(j-1))
 			{
 				sol[i][j]='D';
 				mat[i][j]=(mat[i-1][j-1]) + 1;
 			}
 			else if (mat[i-1][j] > mat[i][j-1])
 			{
 				sol[i][j]='U';
                                mat[i][j]=mat[i-1][j];
 			}
                        else
                        {
                        	sol[i][j]='L';
                        	mat[i][j]=mat[i][j-1];
                        }
                }
        }
        return sol;
 }

 public void stampaLCS(char[][] sol, String word, int i, int j)
 {
  	if (i == 0 || j == 0)
        {
        	System.out.println("*");
                return;
        }
 	else if (sol[i][j] == 'D')
 	{
 		stampaLCS(sol, word, i-1, j-1);
 		System.out.print(word.charAt(i-1));
 	}
        else if (sol[i][j] == 'U') stampaLCS(sol, word, i-1, j);
        else stampaLCS(sol, word, i, j-1);
 }

 public static void main (String args[])throws IOException
 {
        //legge da file le parole
        File f=new File(args[0]);
        FileInputStream fis=new FileInputStream(f);
        InputStreamReader isr=new InputStreamReader(fis);
        BufferedReader br=new BufferedReader(isr);
        String primaParola=br.readLine();
        String secondaParola=br.readLine();
        System.out.println(primaParola);
        System.out.println(secondaParola);
	System.out.println();
	//istanzia e inizializza le due matrici
        int n=(primaParola.length()+1);
        int m=(secondaParola.length()+1);
        Lcs lcs = new Lcs();
 	int [][]matrice = lcs.minit(n,m);
 	char [][]soluzione = lcs.sinit(n,m);
 	lcs.stampaMat(matrice,n,m);
        lcs.stampaMat(soluzione,n,m);
 	//manipola le matrici
        soluzione = lcs.fill(matrice,soluzione,primaParola,secondaParola,n,m);
        lcs.stampaMat(matrice,n,m);
        lcs.stampaMat(soluzione,n,m);
        //stampa le soluzioni
 	lcs.stampaLCS(soluzione,primaParola,n-1,m-1);
	System.out.println();
 }
}
questo è quanto ho scritto (e gira), un ringraziamento di cuore a chi mi saprà aiutare...
__________________
Work in progress...
~ breve.altervista.org
~ www.lartediria.it
BreV& è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2005, 15:02   #2
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Devi darci più indizi... Spiega dove sta il problema nel tuo codice... Cosa non ti riesce ?
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 09-11-2005, 11:12   #3
BreV&
Senior Member
 
L'Avatar di BreV&
 
Iscritto dal: Mar 2004
Città: Pogliano Milanese
Messaggi: 665
dunque, nel mio codice non ci sono problemi, prechè quello è il classico LCS, dove grazie al metodo "stampaLCS" percorro all'indietro la matrice che ho compilato con il metodo "fill" e stampo a video una delle possibili soluzioni ottime. Il mio problema è che il testo dell'esercizio mi richiede la stampa a video di TUTTE le soluzioni ottime e io non ho la più pallida idea di come implementarlo
Mi basterebbe anche solo un "punto di partenza" come quelli che ho visto dare più volte in 3D di questa sezione
__________________
Work in progress...
~ breve.altervista.org
~ www.lartediria.it
BreV& è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Gwynne Shotwell (presidente di SpaceX): ...
ISRO lancerà il primo modulo della stazi...
Lo sfondo animato del tuo PC potrebbe es...
Dopo la RAM, Framework annuncia l'aument...
Google Home Speaker ufficiale: è il prim...
Spotify: i nomi utente stanno per divent...
Il limite vero dei data center AI sono g...
AMD conferma i nuovi Threadripper: Zen 6...
Stop all'ADSL per WindTre: continua la m...
HPE punta sull'IA agentica e dichiara gu...
macOS avvisa quando si incolla un comand...
Everpure ridisegna lo storage per l’IA: ...
NVIDIA RTX Remix 1.5: realizzare remaste...
Come configurare Windows 11 like a pro, ...
Windows 11 cambia finalmente la gestione...
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: 00:41.


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