Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Tutti gli articoli Tutte le news

Vai al Forum
Discussione Chiusa
 
Strumenti
Old 02-12-2008, 13:18   #1
alessia86
Member
 
Iscritto dal: Dec 2008
Messaggi: 125
HELP ME.............. :(

Spero che qualcuno mi aiuti perchè sto davv impazzendo
Allora il mio problema è questo devo creare un albero di caratteri partendo dal seguente vettore v[]=[s, t, u ,d ,i, a ,r ,e] devo creare il seguente albero
“studiare”
“stud” “iare”
“st” “ud” “ia” “re”
“s” “t” “u” “d” “i” “a” “r” “e”
che presenta come foglie i caratteri contenuti nel vettore v,ed il contenuto informativo ad un generico livello i è ottenuto concatenando le stringhe presenti nei suoi nodi figli.

La funz che ho fatto io è la seguente:

void costruisci(AlberoB<char*> & A,char* v[n])
{
Coda<char*> c;
for(int i=0;i<n;i++)
c.inCoda(v[i]);
char S1[80];
char* completo="studiare";
while(!c.vuota() && strcmp(S1,completo)!=0 ){
char S2[80];

strcpy(S1,c.fuoriCoda());
strcpy(S2,c.fuoriCoda());

char S[80];
strcpy(S,S1);

AlberoB<char*> B(S);
AlberoB<char*> C(S2);

strcat(S1,S2);
c1.inCoda(S1);

A.modRadice(S1);
A.insFiglio(SIN,B);
A.insFiglio(DES,C);

}
stampa(A);

}


void stampa(AlberoB<char*> A)
{
if(!A.nullo())
{
cout<<A.radice()<<endl;

stampa(A.figlio(SIN));
stampa(A.figlio(DES));
}

}


Il problema è che nella coda c mi memorizza s,t,u,d,i,a,r,e; ma quando faccio la concatenazione non me li salva nella coda,ma mi ci mette re,re,re,re
ed invece dovrebbe salvarci: st,ud,ia,re,stud,iare,ed infine studiare.
Spero che qualcuno mi aiuta non so davvero come fare
alessia86 è offline  
Old 02-12-2008, 14:21   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Un consiglio: posta il codice tra i tag "CODE" così non si perde l'identazione, e identalo in modo leggibile. In questo modo è più probabile che l'eventuale lettore si prenda la briga di controllare il tuo sorgente (io per esempio, i codici non pubblicati tra i tag appositi non li guardo neanche).
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline  
Old 02-12-2008, 15:47   #3
alessia86
Member
 
Iscritto dal: Dec 2008
Messaggi: 125
Codice:
void costruisci(AlberoB<char*> & A,char* v[n])
{ 
Coda<char*> c;
for(int i=0;i<n;i++)
c.inCoda(v[i]);
char S1[80];
char* completo="studiare";
while(!c.vuota() && strcmp(S1,completo)!=0 ){ 
char S2[80];

strcpy(S1,c.fuoriCoda());
strcpy(S2,c.fuoriCoda());

char S[80];
strcpy(S,S1);

AlberoB<char*> B(S);
AlberoB<char*> C(S2);

strcat(S1,S2);
c1.inCoda(S1);

A.modRadice(S1);
A.insFiglio(SIN,B);
A.insFiglio(DES,C);

}
stampa(A);

}


void stampa(AlberoB<char*> A)
{
if(!A.nullo())
{
cout<<A.radice()<<endl;

stampa(A.figlio(SIN));
stampa(A.figlio(DES));
}

}
Ho seguito il tuo consiglio..spero adesso sia più chiaro
alessia86 è offline  
Old 02-12-2008, 16:22   #4
Vincenzo1968
Bannato
 
Iscritto dal: Mar 2008
Città: Villabate(PA)
Messaggi: 2515
Ciao,

puoi mostrare il codice relativo alla classe AlberoB?
Vincenzo1968 è offline  
Old 02-12-2008, 16:25   #5
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
C'e' una serie di incongruenze in questo codice, che ti porta ad avere il risultato che hai visto.

Prima di tutto, dovresti ricontrollare la struttura dati che hai deciso di utilizzare: si tratta di un albero in cui ogni nodo contiene un puntatore a char.
Va da se' che devi tutte le volte assicurarti che il puntatore sia valido (punti ad un'area di memoria valida e "tutta per se'").
In realta', e' chiaro che tutti i tuoi puntatori vanno a puntare ad una variabile locale (quindi quando uscirai da quella funzione non ci sara' piu' nulla di valido) ed oltrettutto il puntatore e' uguale per tutti i nodi, per cui conterranno tutti la stessa cosa.

Ci sono diverse strategie per correggere il codice. Siccome pero' questo ha l'aria di essere un esercizio, penso sia opportuno che ci dica quali temi della programmazione hai affrontato.

Per esempio: una cosa semplice, che ti risolverebbe i problemi, sarebbe quella di usare delle std::string all'interno nei nodi. Sempre che, ovviamente, li abbia gia' studiati e siano leciti da usare nell'esercizio.
In alternativa, puoi allocare memoria per ogni nodo che crei e copiare il valore all'interno....
__________________
In God we trust; all others bring data
sottovento è offline  
Old 02-12-2008, 16:39   #6
alessia86
Member
 
Iscritto dal: Dec 2008
Messaggi: 125
Allora la classe AlberoB.h è la seguente:
Codice:
#ifndef ALBEROB_H
#define ALBEROB_H

#include <assert.h>

enum Direzione { SIN=0, DES=1 };

template <class T>
struct SNodo{
	T vinfo; // parte informativa
	SNodo *ppadre, *pfiglio[2]; // puntatori al padre e ai due figli
	SNodo( const T& inf ): vinfo(inf)
	{	ppadre = pfiglio[SIN] = pfiglio[DES] = 0;
	}
	~SNodo( ) {delete pfiglio[SIN]; delete pfiglio[DES];}
};

template <class T>
class AlberoB
{
protected:
	SNodo<T>* pradice; // puntatore alla radice
public:

//	FUNZIONI NON COSTANTI
	AlberoB ();
	AlberoB ( const T&);

	//	inserisce l'albero AC come figlio d = SIN/DES di AC
	void insFiglio ( Direzione, AlberoB&);
	// 	estrae il figlio d = SIN/DES
	AlberoB<T> estraiFiglio ( Direzione);
	void modRadice ( const T& );
	// svuota l'albero cancellandone tutti i nodi
	void svuota();
	// svuota l'albero ma senza cancellare i nodi
	void annulla();

//	FUNZIONI COSTANTI
	bool nullo() const;
	// restituisce una copia dell'albero
	AlberoB<T> copia ( ) const;
	//	mostra l'info della radice
	const T& radice   ( ) const;
	// restituisce true se la radice è nodo foglia
	bool foglia () const;
	// restituisce il figlio d = SIN/DES
	AlberoB<T> figlio ( Direzione d ) const;
	//	restituisce il padre eventualmente nullo
	AlberoB<T> padre ( ) const;

};
#endif;


Mentre,la classe AlberoB.cpp è questa:
Codice:
#include "AlberoB.h"

template <class T>
AlberoB<T>::AlberoB () {
	pradice = 0;
}
template <class T>
AlberoB<T>::AlberoB ( const T& a) {
	pradice = new SNodo<T>(a);
}

template <class T>
bool AlberoB<T>::nullo() const
{
	return pradice == 0;
}

//	inserisce l'albero AC come figlio d = SIN/DES di AC
template <class T>
void AlberoB<T>::insFiglio ( Direzione d, AlberoB& AC )
{
	assert( !nullo() );
	//assert( figlio(d).nullo() );
	if ( !AC.nullo() ) {
		pradice->pfiglio[d]=AC.pradice;
		AC.pradice->ppadre=pradice;
	}
}

// 	estrae il figlio d = SIN/DES
template <class T>
AlberoB<T> AlberoB<T>::estraiFiglio ( Direzione d ) {
	assert( !nullo() );
	AlberoB<T> A = figlio(d);
	A.pradice->ppadre=0;
	pradice->pfiglio[d] = 0;
	return A;
}

template <class T>
void AlberoB<T>::modRadice ( const T& a ) {
	assert( !nullo() );
	pradice->vinfo = a;
}

// svuota l'albero cancellandone tutti i nodi
template <class T>
void AlberoB<T>::svuota() {
	delete pradice; pradice = 0;
}

// svuota l'albero ma senza cancellare i nodi
template <class T>
void AlberoB<T>::annulla() {
	pradice = 0;
}

//	FUNZIONI COSTANTI
// restituisce una copia dell'albero
template <class T>
AlberoB<T> AlberoB<T>::copia ( ) const	{
	if ( nullo() ) return AlberoB<T>();
	AlberoB<T> AC(radice());
	AlberoB<T> fs = figlio(SIN).copia();
	AlberoB<T> fd = figlio(DES).copia();
	AC.insFiglio(SIN,fs);
	AC.insFiglio(DES,fd);
	return AC;
}

//	mostra l'info della radice
template <class T>
const T& AlberoB<T>::radice ( ) const {
	assert( !nullo() );
	return pradice->vinfo;
}

// restituisce true se la radice è nodo foglia
template <class T>
bool AlberoB<T>::foglia () const {
	return !nullo()&&figlio(SIN).nullo()&& figlio(DES).nullo();
}

// restituisce il figlio d = SIN/DES
template <class T>
AlberoB<T> AlberoB<T>::figlio ( Direzione d ) const {
	assert( !nullo() );
	AlberoB<T> AC;
	AC.pradice = pradice->pfiglio[d];
	return AC;
}

//	restituisce il padre eventualmente nullo
template <class T>
AlberoB<T> AlberoB<T>::padre ( ) const {
	assert( !nullo() );
	AlberoB<T> AC;
	AC.pradice = pradice->ppadre;
	return AC;
}

alessia86 è offline  
Old 02-12-2008, 16:46   #7
alessia86
Member
 
Iscritto dal: Dec 2008
Messaggi: 125
Quote:
Originariamente inviato da sottovento Guarda i messaggi
C'e' una serie di incongruenze in questo codice, che ti porta ad avere il risultato che hai visto.

Prima di tutto, dovresti ricontrollare la struttura dati che hai deciso di utilizzare: si tratta di un albero in cui ogni nodo contiene un puntatore a char.
Va da se' che devi tutte le volte assicurarti che il puntatore sia valido (punti ad un'area di memoria valida e "tutta per se'").
In realta', e' chiaro che tutti i tuoi puntatori vanno a puntare ad una variabile locale (quindi quando uscirai da quella funzione non ci sara' piu' nulla di valido) ed oltrettutto il puntatore e' uguale per tutti i nodi, per cui conterranno tutti la stessa cosa.

Ci sono diverse strategie per correggere il codice. Siccome pero' questo ha l'aria di essere un esercizio, penso sia opportuno che ci dica quali temi della programmazione hai affrontato.

Per esempio: una cosa semplice, che ti risolverebbe i problemi, sarebbe quella di usare delle std::string all'interno nei nodi. Sempre che, ovviamente, li abbia gia' studiati e siano leciti da usare nell'esercizio.
In alternativa, puoi allocare memoria per ogni nodo che crei e copiare il valore all'interno....
qst è un esercizio..ho finito da poco di seguire il corso di algoritmi e strutture dati..Devo utilizzare la struttura ad albero utilizzando la classe AlberoB.cpp che ho appena riportato sopra..cmq non so se magari mi illustri qualche strategia..
alessia86 è offline  
Old 02-12-2008, 16:56   #8
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da alessia86 Guarda i messaggi
qst è un esercizio..ho finito da poco di seguire il corso di algoritmi e strutture dati..Devo utilizzare la struttura ad albero utilizzando la classe AlberoB.cpp che ho appena riportato sopra..cmq non so se magari mi illustri qualche strategia..
Che dovevi usare l'albero era chiaro. Quello che voglio dire e' che nell'albero ci metti un "char *".

Ad ogni ciclo crei un nodo scrivendo
Codice:
AlberoB<char*> B(S);
AlberoB<char*> C(S2);
pertanto tutti i nodi che crei ad ogni ciclo punteranno TUTTI a S o S2! Quindi, quando cambi il valore di S o S2, cambi TUTTI i nodi allo stesso tempo!
Inoltre, anche B e C sono dichiarate localmente, pertanto quando questa funzione termina, non esistono piu'! Quello che vedi da quel momento in poi e' soltanto fuffa.

Purtroppo ho finito l'universita' parecchi lustri fa e non so cos'e' un corso di "Algoritmi e Strutture Dati", spero che qualcuno nel forum lo sappia.
Immagino pero' che tu conosca la memoria dinamica.... ecco: prova a riscrivere creando i nodi con new() ed assegnando loro delle stringhe create con new[], qualcosa del tipo

Codice:
S = new char[LENGTH];
// Qui devi riempire S
AlberoB<char*> *B = new AlberoB<char*>(S);

Alternativamente, puoi dichiarare l'albero come di tipo
AlberoB<std::string> B;
ed assegnargli delle stringhe stl.
__________________
In God we trust; all others bring data
sottovento è offline  
Old 02-12-2008, 17:46   #9
alessia86
Member
 
Iscritto dal: Dec 2008
Messaggi: 125
Grazie sottovento..adesso ci provo subito..
alessia86 è offline  
Old 02-12-2008, 19:56   #10
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
http://www.hwupgrade.it/forum/showthread.php?t=1649196

Inoltre non va bene il titolo generico: http://www.hwupgrade.it/forum/showthread.php?t=693363
cionci è offline  
 Discussione Chiusa


Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
La nave elettrica più grande mai ...
Spusu lancia il Wi-Fi Calling: come funz...
Questo robot impara a muovere le labbra ...
iPhone 17 annienta la concorrenza in Cin...
La nuova Xiaomi SU7 batte un record: 4.2...
È possibile copiare i qubit: dei ...
BYD alza ulteriormente l'asticella: batt...
Il nuovo razzo spaziale riutilizzabile c...
L'ex leader di Assassin's Creed porta Ub...
Il razzo spaziale NASA SLS e la capsula ...
Samsung Galaxy S26 Ultra: quattro colora...
AWS investe 1,2 miliardi in Italia. Coin...
La navicella cinese Shenzhou-20 con il f...
I piani Business ed Education di Google ...
Ceres-2 e Lunga Marcia 3B: la Cina falli...
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: 23:13.


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