Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Lenovo IdeaPad Slim 3: un notebook Snapdragon X economico
Lenovo IdeaPad Slim 3: un notebook Snapdragon X economico
Forte della piattaforma Qualcomm Snapdragon X, il notebook Lenovo IdeaPad Slim 3 riesce a coniugare caratteristiche tecniche interessanti ad uno chassis robusto, con autonomia di funzionamento a batteria che va ben oltre la tipica giornata di lavoro. Un notebook dal costo accessibile pensato per l'utilizzo domestico o in ufficio, soprattutto con applicazioni native per architettura ARM
Recensione OnePlus Watch 3 43mm: lo smartwatch che mancava per i polsi più piccoli
Recensione OnePlus Watch 3 43mm: lo smartwatch che mancava per i polsi più piccoli
OnePlus risponde alle esigenze di chi cerca un dispositivo indossabile dalle dimensioni contenute con OnePlus Watch 3 43mm. La versione ridotta del flagship mantiene gran parte delle caratteristiche del modello maggiore, offrendo un'esperienza completa in un formato compatto. Il suo limite più grande è abbastanza ovvio: l'autonomia non è il punto di forza di questo modello, ma si raggiungono comodamente le due giornate piene con un uso normale.
BOOX Note Air4 C è uno spettacolo: il tablet E Ink con Android per lettura e scrittura
BOOX Note Air4 C è uno spettacolo: il tablet E Ink con Android per lettura e scrittura
BOOX Note Air4 C rappresenta l'ultima incarnazione della categoria dei tablet E Ink a colori di Onyx, e combina le prestazioni di un dispositivo Android con l'ottima tecnologia Kaleido 3 per il display. Con schermo da 10,3 pollici, un processore Qualcomm Snapdragon 750G e 6 GB di RAM, promette un'esperienza completa per lettura, scrittura e produttività. Il prezzo lo posiziona nel segmento premium, ma questo dispositivo è un vero spettacolo!
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


Lenovo IdeaPad Slim 3: un notebook Snapdragon X economico Lenovo IdeaPad Slim 3: un notebook Snapdragon X ...
Recensione OnePlus Watch 3 43mm: lo smartwatch che mancava per i polsi più piccoli Recensione OnePlus Watch 3 43mm: lo smartwatch c...
BOOX Note Air4 C è uno spettacolo: il tablet E Ink con Android per lettura e scrittura BOOX Note Air4 C è uno spettacolo: il tab...
Recensione Sony Xperia 1 VII: lo smartphone per gli appassionati di fotografia Recensione Sony Xperia 1 VII: lo smartphone per ...
Attenti a Poco F7: può essere il best buy del 2025. Recensione Attenti a Poco F7: può essere il best buy...
Tragedia in Francia: giovane streamer mu...
Bernie Sanders appoggia Trump sulla part...
Ayaneo Pocket DS: la console Android isp...
Sconti sui Kindle: Amazon li vende da 89...
Il Camera Control non convince: sui futu...
Giù di altri 50€, solo 498€: ECOV...
Sostituire i lavoratori junior con l'AI ...
Google presenta i nuovi Pixel 10: con il...
Google lancia Pixel Watch 4 e altre novi...
Arriva la conferma: Xiaomi vuole vendere...
Workday vittima di attacco, penetrato un...
Italia e fotovoltaico, superati i 2 mili...
Qualcomm svela lo Snapdragon 7s Gen 4: b...
ROG Xbox Ally: svelata la data di uscita...
Meta porta il doppiaggio AI per i Reel d...
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: 07:52.


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