Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Abbiamo provato per voi il nuovo DLC lanciato a sorpresa da Blizzard per Diablo II: Resurrected e quella che segue è una disamina dei nuovi contenuti che abbiamo avuto modo di sperimentare nel corso delle nostre sessioni di gioco, con particolare riguardo per la nuova classe dello Stregone
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-01-2010, 19:27   #1
domenico88
Senior Member
 
L'Avatar di domenico88
 
Iscritto dal: Dec 2009
Messaggi: 1056
[C]Alberi binari

Salve a tutti

Sto smanettando un pò con gli alberi binari, implementando nei programmi algoritmi ricorsivi per visita, inserimento, ricerca ecc.

Volevo provare a scrivere un algoritmo per la visita(per contare il numero di nodi) di un albero in versione iterativa però non saprei proprio da dove cominciare

Se qualcuno ha qualche idea mi farebbe molto piacere!
Grazie a tutti!
domenico88 è offline   Rispondi citando il messaggio o parte di esso
Old 30-01-2010, 23:02   #2
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Per gli alberi e le visite devi chiedere a Vincenzo1968.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2010, 02:57   #3
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Non è difficile.
Immagina una visita in-order comunissima, fatta ricorsivamente:
Codice:
algoritmo InOrderTraversal(albero T)
{
    se T non è nullo {
        InOrderTraversal(nodo sinistro di T);
        visita il nodo T;
        InOrderTraversal(nodo destro di T);
    }
}
Qui si sfrutta pesantemente lo stack di sistema per risalire nell'albero ogni volta che si ha finito di visitare un nodo. Per farlo iterativamente di solito si fa la stessa identica cosa che implicitamente fa anche l'algoritmo ricorsivo: si usa uno stack.

Verrebbe fuori una cosa del genere:
Codice:
algoritmo InOrderTraversal(albero T)
{
    stack S;
    nodo N;

    N = radice di T;

    ripeti {
        finché N non è nullo {
            aggiungi N in cima alla pila S;
            N = figlio sinistro di N;
        }

        se la pila S è vuota {
            esci;
        }

        N = preleva la cima della pila S;
        visita N;

        N = figlio destro di N;
    }
}
C'è anche un altro modo di fare la visita iterativa di un albero binario, non richiede l'utilizzo di stack e bastano un paio di puntatori. Però è più complicata da scrivere.

ciao
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2010, 14:15   #4
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
Per gli alberi e le visite devi chiedere a Vincenzo1968.
ti confondi con le macchine a stati
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2010, 15:05   #5
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Quote:
Originariamente inviato da fero86 Guarda i messaggi
ti confondi con le macchine a stati
No, ha anche diversi tutorial su alberi binari (autobilancianti e non) sul suo sito...
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2010, 15:15   #6
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da DanieleC88 Guarda i messaggi
No, ha anche diversi tutorial su alberi binari (autobilancianti e non) sul suo sito...
Sul quale però non pubblica un articolo nuovo da eoni... gli organizziamo un autodafè?
__________________

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
Old 31-01-2010, 15:43   #7
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
In verità stavo pensando di scrivere qualcosina io sugli alberi AVL, anche se non sono propriamente la fonte più autorevole... e comunque sì, un bel autodafè ci sta tutto.
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2010, 21:01   #8
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
Quote:
Originariamente inviato da DanieleC88 Guarda i messaggi
In verità stavo pensando di scrivere qualcosina io sugli alberi AVL,
LOL*!!!

*per capire la mia ilaritá bisogna conoscere alcuni eventi di vita reale



Quote:
anche se non sono propriamente la fonte più autorevole...
come no?? dopo il botto che hai fatto ad algoritmi??
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 01-02-2010, 01:41   #9
domenico88
Senior Member
 
L'Avatar di domenico88
 
Iscritto dal: Dec 2009
Messaggi: 1056
grazie a tutti per le risp
dovrei usare una pila per ricreare la situazione che si crea in memoria con le chiamate ricorsive, non ci avevo proprio penato...
domenico88 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
Spotify introduce 'Taste Profile': il co...
Sole e pioggia insieme: il nuovo pannell...
AWS e Cerebras uniscono le forze: nuova ...
Windows 11: accesso al drive C: bloccato...
BYD pronta a comprare un marchio storico...
Windows 11 si prepara ai monitor oltre i...
Apple avrebbe fissato un target di vendi...
Ultimi giorni per sfruttare le Offerte d...
I migliori smartphone in offerta ora su ...
Le migliori TV delle Offerte di Primaver...
Uno dei robot più avanzati del 2025 crol...
Robot aspirapolvere con stazione automat...
Il nuovo top di gamma compatto di OPPO n...
Nilox aggiorna la sua gamma di fat e-bik...
Meta valuta tagli fino al 20% della forz...
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: 00:03.


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