Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Xiaomi ha portato Redmi Watch 6 anche sul mercato italiano, puntando su un display AMOLED da 2,07 pollici con picco di luminosità a 2000 nit, frame in alluminio da 9,9mm e un'autonomia dichiarata di 12 giorni. Lo smartwatch gira su HyperOS 3 e integra GPS, Bluetooth 5.4 e oltre 150 sport mode. Il tutto a meno di 100 euro
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Con 22 tasti, il pulsante 5D, lo Shift Mode e il sensore PixArt 3395 da 26.000 DPI, il nuovo mouse wireless di Mad Catz si rivolge in modo preciso ai giocatori di MMO e RPG. Ma chi conosce già il R.A.T. 8+ ADV si accorgerà subito di quanto i due prodotti condividano, e di dove invece divergono
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC
Abbiamo provato la Gigabyte Radeon RX 9070 GRE Gaming OC, nuova proposta RDNA 4 che si inserisce tra GeForce RTX 5060 Ti e RTX 5070. Prestazioni solide in rasterizzazione e ray tracing, frequenze elevate grazie all'overclock di fabbrica e raffreddamento efficace: ecco come si comporta nei nostri test.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-12-2003, 22: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, 11: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 11:16.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 09-12-2003, 12: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, 15: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, 22: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, 07: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, 12: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, 12: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, 12: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, 12: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, 12: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, 12: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, 13: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, 19: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, 21: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, 19: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 19:18.
mardeg è offline   Rispondi citando il messaggio o parte di esso
Old 23-09-2009, 08: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 08:42.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 23-09-2009, 19: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, 19: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, 08: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


Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
Reolink OMVI 3i WiFi: videosorveglianza più intelligente e facile da usare Reolink OMVI 3i WiFi: videosorveglianza pi&ugrav...
Recensione Vivo X300 Ultra: fotocamera eccezionale, ma prezzo proibitivo Recensione Vivo X300 Ultra: fotocamera ecceziona...
Xference e Aruba insieme per l'IA privat...
Google Wallet, in arrivo i documenti d'i...
Recensione OPPO Enco Clip2: tanta tecnol...
Altro passo dei cinesi in Europa: Chery ...
AMD FSR 4.1: l'architettura RDNA 3.5 pot...
L'Economist dice di non dare la colpa al...
Meta frena sul tracciamento dei dipenden...
Falla zero-click su Android, anche Linux...
AMD ha nascosto il vero segreto di EXPO ...
TRYX porta la personalizzazione a un nuo...
Designer di auto cinesi all'attacco di F...
Oltre 3.000 posti di lavoro a rischio: l...
Uber taglia il 23% del personale HR, ma ...
Amazon TOP 7 rinnovata: in posizione 2 u...
HTTP/2 Bomb: il nuovo attacco DoS che ab...
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: 15:25.


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