Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-12-2003, 23:02   #1
Gen.Web
Senior Member
 
L'Avatar di Gen.Web
 
Iscritto dal: Dec 2002
Città: Loano (SV)
Messaggi: 1172
[c/c++] utilità degli alberi binari

Qualcuno mi può dire l'utilità di queste strutture? Perchè senza una ragione non riesco a studiarli
Gen.Web è offline   Rispondi citando il messaggio o parte di esso
Old 09-12-2003, 12:13   #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
Ad esempio sono utili in algoritmi di ordinamento (heap sort)... Nelle strutture di memorizzazione dei database (BTree, B+Tree)...
Vengono usati anche in alcuni algoritmi di codifica/compressione...codifica di Huffman...algoritmo usato in praticamente tutti i sistemi di compressione delle informazioni...
E poi chi più ne ha più ne metta...non è certo una struttura poco usata !!!

Ultima modifica di cionci : 09-12-2003 alle 12:16.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 09-12-2003, 13:37   #3
Luc@s
Senior Member
 
L'Avatar di Luc@s
 
Iscritto dal: Apr 2002
Città: Vigevano(PV)
Messaggi: 2124
filesystem
__________________
Gnu/Linux User
Luc@s è offline   Rispondi citando il messaggio o parte di esso
Old 09-12-2003, 16:36   #4
jonson
Senior Member
 
L'Avatar di jonson
 
Iscritto dal: Jan 2003
Città: Lecce
Messaggi: 792
Re: utilità degli alberi binari in c/c++

Quote:
Originariamente inviato da Gen.Web
Qualcuno mi può dire l'utilità di queste strutture? Perchè senza una ragione non riesco a studiarli
concordo

è senza dubbio una delle parti più rognose, almeno del mio corso
__________________
Chieftec DA-01WD - Enermax 430W - MSI K8N Neo2 Platinum - A64 3000+ @ 2610 Cooled By K10 Hurican - 512MB Corsair XMS PC3200 XL - PixelView 6600GT - WD Raptor 36GB+Maxtor 80 GB - Pioneer DVR A05 - LiteOn 52X-24X-52X - Acer TM661
"La Famigghia": SetiWarrior di 8° livello
jonson è offline   Rispondi citando il messaggio o parte di esso
Old 09-12-2003, 23:45   #5
Gen.Web
Senior Member
 
L'Avatar di Gen.Web
 
Iscritto dal: Dec 2002
Città: Loano (SV)
Messaggi: 1172
ragazzi qualcuno ha qualche guida FATTA BENE sugli alberi? Ci hanno fatto comprare un libro sul c++ dove praticamente non c'è traccia di code, alberi, pile, ecc...
Il 22 ho l'esame
Gen.Web è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2003, 08:21   #6
jonson
Senior Member
 
L'Avatar di jonson
 
Iscritto dal: Jan 2003
Città: Lecce
Messaggi: 792
Quote:
Originariamente inviato da Gen.Web
ragazzi qualcuno ha qualche guida FATTA BENE sugli alberi? Ci hanno fatto comprare un libro sul c++ dove praticamente non c'è traccia di code, alberi, pile, ecc...
Il 22 ho l'esame
io uso un libro in Inglese dove ci sono tutte le strutture dati principali. il prof del mio corso ha ricopiato ogni capitolo del libro in presentazioni powerpoint. se ti interessano dimmelo che ti spedisco quello che ti serve e sono complete di codice e di analisi per tutte le funzioni implementate .
__________________
Chieftec DA-01WD - Enermax 430W - MSI K8N Neo2 Platinum - A64 3000+ @ 2610 Cooled By K10 Hurican - 512MB Corsair XMS PC3200 XL - PixelView 6600GT - WD Raptor 36GB+Maxtor 80 GB - Pioneer DVR A05 - LiteOn 52X-24X-52X - Acer TM661
"La Famigghia": SetiWarrior di 8° livello
jonson è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2003, 13:07   #7
Luc@s
Senior Member
 
L'Avatar di Luc@s
 
Iscritto dal: Apr 2002
Città: Vigevano(PV)
Messaggi: 2124
Quote:
Originariamente inviato da jonson
io uso un libro in Inglese dove ci sono tutte le strutture dati principali. il prof del mio corso ha ricopiato ogni capitolo del libro in presentazioni powerpoint. se ti interessano dimmelo che ti spedisco quello che ti serve e sono complete di codice e di analisi per tutte le funzioni implementate .

[email protected]

Tnk 1000000000000000000000000000000000000000000000000000
__________________
Gnu/Linux User
Luc@s è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2003, 13:26   #8
jonson
Senior Member
 
L'Avatar di jonson
 
Iscritto dal: Jan 2003
Città: Lecce
Messaggi: 792
Quote:
Originariamente inviato da Luc@s
[email protected]

Tnk 1000000000000000000000000000000000000000000000000000
ti interessano solo gli alberi binari? non per niente ma ogni presentazione è sui 500-600 k e io con il 56K
cmq dimmi cosa ti interessa che cerco di spedirtelo al + presto
__________________
Chieftec DA-01WD - Enermax 430W - MSI K8N Neo2 Platinum - A64 3000+ @ 2610 Cooled By K10 Hurican - 512MB Corsair XMS PC3200 XL - PixelView 6600GT - WD Raptor 36GB+Maxtor 80 GB - Pioneer DVR A05 - LiteOn 52X-24X-52X - Acer TM661
"La Famigghia": SetiWarrior di 8° livello
jonson è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2003, 13:31   #9
Luc@s
Senior Member
 
L'Avatar di Luc@s
 
Iscritto dal: Apr 2002
Città: Vigevano(PV)
Messaggi: 2124
Quote:
Originariamente inviato da jonson
ti interessano solo gli alberi binari? non per niente ma ogni presentazione è sui 500-600 k e io con il 56K
cmq dimmi cosa ti interessa che cerco di spedirtelo al + presto
alberi binari.
Tnk 10000000000000000000000000000000000 ancora
__________________
Gnu/Linux User
Luc@s è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2003, 13:35   #10
Gen.Web
Senior Member
 
L'Avatar di Gen.Web
 
Iscritto dal: Dec 2002
Città: Loano (SV)
Messaggi: 1172
mi accodo... alberi binari
[email protected]
Gen.Web è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2003, 13:36   #11
Luc@s
Senior Member
 
L'Avatar di Luc@s
 
Iscritto dal: Apr 2002
Città: Vigevano(PV)
Messaggi: 2124
Quote:
Originariamente inviato da Gen.Web
mi accodo... alberi binari
[email protected]
Se me li manda poi te le passo io(ADSL rulez )
__________________
Gnu/Linux User
Luc@s è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2003, 13:40   #12
jonson
Senior Member
 
L'Avatar di jonson
 
Iscritto dal: Jan 2003
Città: Lecce
Messaggi: 792
Quote:
Originariamente inviato da Luc@s
Se me li manda poi te le passo io(ADSL rulez )
adesso ti mando quella degli alberi binari e alberi binari di ricerca che è tutto in 1

ah dimenticavo di dirvi che è tutto in inglese, cmq molto semplice e nn ci sono paroloni
__________________
Chieftec DA-01WD - Enermax 430W - MSI K8N Neo2 Platinum - A64 3000+ @ 2610 Cooled By K10 Hurican - 512MB Corsair XMS PC3200 XL - PixelView 6600GT - WD Raptor 36GB+Maxtor 80 GB - Pioneer DVR A05 - LiteOn 52X-24X-52X - Acer TM661
"La Famigghia": SetiWarrior di 8° livello
jonson è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2003, 14:03   #13
Gen.Web
Senior Member
 
L'Avatar di Gen.Web
 
Iscritto dal: Dec 2002
Città: Loano (SV)
Messaggi: 1172
Quote:
Originariamente inviato da jonson
adesso ti mando quella degli alberi binari e alberi binari di ricerca che è tutto in 1

ah dimenticavo di dirvi che è tutto in inglese, cmq molto semplice e nn ci sono paroloni

tutto di guadagnato, si impara
Gen.Web è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2003, 20:59   #14
Mezzetti0903
Senior Member
 
Iscritto dal: Nov 2000
Messaggi: 279
!

Mi posso aggregar??

[email protected]



grazie!!!
__________________
In un arco di tempo abbastanza lungo l'indice di sopravvivenza di ognuno scende a zero
Mezzetti0903 è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2003, 22:12   #15
jonson
Senior Member
 
L'Avatar di jonson
 
Iscritto dal: Jan 2003
Città: Lecce
Messaggi: 792
chiedi a luc@s, è lui che sta smistando
__________________
Chieftec DA-01WD - Enermax 430W - MSI K8N Neo2 Platinum - A64 3000+ @ 2610 Cooled By K10 Hurican - 512MB Corsair XMS PC3200 XL - PixelView 6600GT - WD Raptor 36GB+Maxtor 80 GB - Pioneer DVR A05 - LiteOn 52X-24X-52X - Acer TM661
"La Famigghia": SetiWarrior di 8° livello
jonson è offline   Rispondi citando il messaggio o parte di esso
Old 22-09-2009, 20:05   #16
mardeg
Junior Member
 
Iscritto dal: Sep 2009
Messaggi: 1
albero binario

guardate questo programma qualcuno mi sa spiegare bene le istruzioni evidenziate in rosso


#include <iostream>
using namespace std;

class tree
{
private:
int dato;
tree *left;
tree *right;

public:
tree(void);
~tree(void);
void set(int numero);
int get(void);
tree *get_left(void);
tree *get_right(void);
void point_at_left(tree *where_to_point);
void point_at_right(tree *where_to_point);
};

tree::tree(void)
{
dato=1;
left=NULL;
right=NULL;
}

tree::~tree(void)
{
dato=0;
left=NULL;
right=NULL;
}

void tree::set(int numero)
{
dato=numero;
}

int tree::get(void)
{
return dato;
}

tree *tree::get_left(void)
{
return left;
}

tree *tree::get_right(void)
{
return right;
}

void tree:oint_at_left(tree *where_to_point)
{
left=where_to_point;
}

void tree:oint_at_right(tree *where_to_point)
{
right=where_to_point;
}

tree *rootPtr=NULL;

void inserisci(tree *startPtr,int numero);
void simmetrica(tree *startPtr);

void inserisci(tree *startPtr,int numero)
{
tree *newPtr;

if(numero<startPtr->get())
{
if ((startPtr->get_left())==NULL)
{
newPtr=new(tree);
newPtr->set(numero);

startPtr->point_at_left(newPtr);
}

else
inserisci(startPtr->get_left(),numero);
}

else if(numero>startPtr->get())
{
if((startPtr->get_right())==NULL)
{
newPtr=new(tree);
newPtr->set(numero);
startPtr->point_at_right(newPtr);
}

else
inserisci(startPtr->get_right(),numero);

}

else
cout << "Elemento duplicato NON INSERITO" << endl;
}

void simmetrica(tree *startPtr)
{
if (startPtr!=NULL)
{
simmetrica(startPtr->get_left());
cout << "Nodo-> " << startPtr->get() << endl;
simmetrica(startPtr->get_right());
}

}


int
main(void)
{
int elem=9;
tree *tempPtr;

do{
cout << "Inserisci elemento(-1 per terminare) -> ";
cin >> elem;
if(elem!=-1)
{
if(rootPtr==NULL)
{
tempPtr=new(tree);
tempPtr->set(elem);
rootPtr=tempPtr;
}

else
inserisci(rootPtr,elem);

}

}while(elem!=-1);

simmetrica(rootPtr);

system("pause");
return 0;
}

Ultima modifica di mardeg : 22-09-2009 alle 20:18.
mardeg è offline   Rispondi citando il messaggio o parte di esso
Old 23-09-2009, 09:32   #17
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Per prima cosa: usa il tag "CODE" per pubblicare del codice, serve per non perdere l'dentazione:
Codice:
[cut]

// definizione metodo "inserisci"
void inserisci(tree *startPtr,int numero)
{
    tree *newPtr;

    if(numero<startPtr->get())
    {
        if ((startPtr->get_left())==NULL)
        {
            newPtr=new(tree);
            newPtr->set(numero);
            startPtr->point_at_left(newPtr);
        }
        else
            inserisci(startPtr->get_left(),numero);
    }
    else if(numero>startPtr->get())
    {
        if((startPtr->get_right())==NULL)
        {
            newPtr=new(tree);
            newPtr->set(numero);
            startPtr->point_at_right(newPtr);
        }
        else
            inserisci(startPtr->get_right(),numero);
    }
    else
        cout << "Elemento duplicato NON INSERITO" << endl;
}


// definizione metodo "simmetrica"
void simmetrica(tree *startPtr)
{
    if (startPtr!=NULL)
    {
        simmetrica(startPtr->get_left());
        cout << "Nodo-> " << startPtr->get() << endl;
        simmetrica(startPtr->get_right());
    }
}
[cut]
Detta in due parole: la funzione "inserisci" implementa l'inserimento di un elemento in un albero binario, evitando l'inserimento di elementi duplicati.

Parte controllando se l'elemento da inserire è minore o maggiore dell'elemento del nodo indicato (startPtr): se è minore e startPtr non ha un figlio sinistro allora crea un nuovo nodo che contiene l'elemento da inserire e lo collega come figlio sinistro di startPtr; se invece stratPtr ha già un figlio sinistro, "inserisci" chiama ricorsivamente se stesso passando come nodo di riferimento il figlio sinistro di startPtr.
Allo stesso modo, se l'elemento da inserire risulta maggiore di startPtr e startPtr non ha un figlio destro allora crea un nuovo nodo che contiene l'elemento da inserire e lo collega come figlio destro di startPtr; se invece stratPtr ha già un figlio destro, "inserisci" chiama ricorsivamente se stesso passando come nodo di riferimento il figlio destro di startPtr.
Infine, se l'elemendo da inserire non è ne minore ne maggiore dell'elemento di startPtr, allora "inserisci" non lo inserisce (niente duplicati) e stampa un messaggio.

La funzione "simmetrica" invece stampa il valore di tutti i nodi figli a partire da un nodo radice (quello passato come parametro alla funzione) esplorando l'albero con una visita inorder (nodo figlio sinistro, nodo padre, nodo figlio destro). Anche questa funzione è ricorsiva.

Per saperne di più sulle modalità di tree traversal, qui c'è qualcosa.
__________________

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)

Ultima modifica di banryu79 : 23-09-2009 alle 09:42.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 23-09-2009, 20:18   #18
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
Quote:
Originariamente inviato da Gen.Web Guarda i messaggi
Qualcuno mi può dire l'utilità di queste strutture? Perchè senza una ragione non riesco a studiarli
nel caso generale servono a rappresentare dati che hanno quel tipo di correlazione, cioé dati organizzati gerarchicamente dove ciascuna entitá é legata ad altre due.

nelle loro varianti hanno anche delle grosse utilitá algoritmiche: esistono infatti gli alberi binari ordinati che permettono nel caso migliore di trovare un'informazione in tempo logaritmico anziché lineare; poi siccome quello é solo il caso migliore, mentre nel caso peggiore il tempo é sempre lineare, esistono gli alberi AVL anche noti come autobilancianti, per i quali il tempo di ricerca é logaritmico in ogni caso. infine esiste una generalizzazione degli alberi AVL che sono gli alberi RB (red-black) e permettono una maggiore efficienza in fase di inserzione e rimozione al costo di potenziali rallentamenti molto contenuti in fase di ricerca.



Quote:
Originariamente inviato da Luc@s Guarda i messaggi
filesystem
pietá!
per i filesystem si usano tutt'al piu i B-trees.
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 23-09-2009, 20:25   #19
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
altra utilitá degli alberi binari: esiste una notazione che permette ad essi di rappresentare alberi N-ari. infatti un albero N-ario puó essere rappresentanto come un grafo in cui ogni nodo fa riferimento al primo dei suoi figli ed ogni figlio da riferimento al prossimo dei suoi fratelli (quindi per memorizzare i figli si usa una lista linkata). di conseguenza ogni nodo fa riferimento ad altri due nodi, il primo figlio e il fratello, e quindi si tratta di un albero binario.

l'algoritmo di traduzione appena descritto é praticamente una biezione tra l'insieme degli alberi binari e quello degli alberi N-ari.
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2009, 09:10   #20
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Che fai fero, necoposting?
Comunque ottime le tue integrazioni, almeno se in futuro qualcuno incapperà nel topic troverà molte indicazioni. A tal proposito, aggiungo alla tua descrizione dei vari tipi di albero un articolo di Robert Sedgewick su una variante che lui chiama Left Leaning Red-Black Trees.
__________________

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   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Apple punterà sull'architettura c...
NASA Curiosity: i processi non biologici...
Sega conferma l'arrivo di tanti nuovi gi...
La serie POCO X8 è pronta al debu...
Apple conferma che l'arrivo della 'nuova...
Le vendite di Square Enix sono in netto ...
iPhone 17e si mostra in un video 'first ...
Il nuovo Xiaomi Watch 5 è pronto ...
Steam Deck è out of stock in dive...
Le migliori offerte Amazon del weekend, ...
PC più potente, meno spesa: su Amazon ta...
Amazon Haul: come fare acquisti 'pazzi' ...
Threads permetterà agli utenti di...
Monitor gaming in offerta su Amazon: 180...
Samsung vuole riconquistare la leadershi...
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: 20:45.


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