Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Con un prezzo di 2.999 euro, il Panasonic Z95BEG entra nella fascia ultra-premium dei TV OLED: pannello Primary RGB Tandem, sistema di raffreddamento ThermalFlow, audio Technics integrato e funzioni gaming avanzate lo pongono come un punto di riferimento
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione
Abbiamo provato per diverse settimane il nuovo Magic V5 di HONOR, uno smartphone pieghevole che ci ha davvero stupito. Il device è il più sottile (solo 4.1mm) ma non gli manca praticamente nulla. Potenza garantita dallo Snapdragon 8 Elite, fotocamere di ottima qualità e batteria in silicio-carbonio che garantisce un'ottima autonomia. E il Prezzo? Vi diciamo tutto nella nostra recensione completa.
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


Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro) Recensione Google Pixel 10 Pro XL: uno zoom 100x...
Lenovo IdeaPad Slim 3: un notebook Snapdragon X economico Lenovo IdeaPad Slim 3: un notebook Snapdragon X ...
Sony mostra in anteprima la propria tecn...
Dreame A3 AWD: a IFA 2025 debutta il rob...
OpenAI, il chip proprietario per l'AI &e...
OnePlus e Hasselblad si separano: una nu...
Ayaneo Pocket Air Mini: la retro console...
Amazon sfida tutti: crollano iPhone e Ma...
MacBook Pro con chip M4 a 1.649€ e MacBo...
Dreame a IFA 2025: robot capaci di salir...
AirPods 4 contro AirPods Pro 2: Amazon l...
Amazon in furore da sconti: tutti gli iP...
RTX Hair in Indiana Jones e l'Antico Cer...
Robot aspirapolvere super scontati su Am...
Windows Mixed Reality: un ingegnere Micr...
Qualcomm: Intel non è ancora pron...
BMW e Qualcomm lanciano Snapdragon Ride ...
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: 03:38.


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