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 25-06-2008, 16:10   #1
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2688
[Pseudo Codice]Ricerca di un elemento in un albero binario

Ciao ragazzi,
ho qualche dubbio per l'esame di algoritmi...c'è un esercizio dove chiede di scrivere in pseudo codice (nessun linguaggio specifico quindi...ditemi solo se lalogica può essere corretta) una procedura ricorsiva che verfichi se esiste un nodo dell'albero che abbia un certo contenuto informativo (identficato da una chiave k)
Ah questo non è un albero binario di ricerca (che vedrò nel prossimo capitolo insieme agli AVL) ma un banale albero binario che contiene in ogni nodo qualcosa che potrei voler ricercare.

io l'ho pensato così:

Codice:
CercaElemento(nodo r, chiave k){

      IF(r == null) THEN return null // Caso base 1: gli stò passando un albero vuoto
      IF(chiave(r) == k) THEN return k // Caso base 2: ho trovato l'elemento che cerco

      ELSE    // Caso generale
          CercaElemento(nodo figlio sinistro di r, chiave k)
          CercaElemento(nodo figlio destro di r, chiave k)
}
Così facendo se gli passo un albero vuoto ritorna null al chiamante il che può succedere se l'albero di partenza è vuoto o se raggiunge una foglia: torna indietro restituendo null e se alla fine non ha trovato nulla la funzione dovrebbe restituire proprio null al chiamante di partenza.
Se invece trova l'elemento lo ritorna al chiamante altrimenti scende prima sul sottoalbero sinistro e poi sul sottoalbero destro effettaundo la ricerca.

Pensate che possa andare bene? la soluzione del professore è un po' diversa...ho sbagliato qjualcosa?

Grazie
Andrea
D4rkAng3l è offline   Rispondi citando il messaggio o parte di esso
Old 25-06-2008, 18:30   #2
khelidan1980
Senior Member
 
L'Avatar di khelidan1980
 
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
questo codice comunque non funzionerà,quando tu chiami la tua funzione sul nodo che contiene la chiave voluta,il tuo if ritorna k al ramo else della chiamata precedente,e poi?quando sei nell'else non hai nessun return
__________________
Khelidan
khelidan1980 è offline   Rispondi citando il messaggio o parte di esso
Old 25-06-2008, 18:36   #3
Albi89
Senior Member
 
Iscritto dal: May 2004
Città: Napoli
Messaggi: 773
Quote:
Originariamente inviato da khelidan1980 Guarda i messaggi
questo codice comunque non funzionerà,quando tu chiami la tua funzione sul nodo che contiene la chiave voluta,il tuo if ritorna k al ramo else della chiamata precedente,e poi?quando sei nell'else non hai nessun return
Penso che dovrebbero essere due return nell'else... per il resto mi sembra ok =P
__________________
If builders built buildings the way programmers wrote programs, then the first woodpecker that came along would destroy civilization.
--Gerald Weinberg
Albi89 è offline   Rispondi citando il messaggio o parte di esso
Old 25-06-2008, 19:19   #4
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Quote:
Originariamente inviato da Albi89 Guarda i messaggi
Penso che dovrebbero essere due return nell'else... per il resto mi sembra ok =P
Non esattamente, in tal caso verrebbe restituito solo il risultato della visita sul sottoalbero sinistro: in pratica sta facendo una visita in preorder, dunque, se la chiave non è la radice, bisogna restituire il valore della visita sul sottoalbero sinistro quando questa non dà NULL, altrimenti restituire il valore della visita sul sottoalbero destro.

Codice:
[...]
  ELSE    // Caso generale
          risultato = CercaElemento(nodo figlio sinistro di r, chiave k)
          if (!risultato)
          {
                return CercaElemento(nodo figlio destro di r, chiave k)
          }
          return risultato
__________________

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 25-06-2008, 19:25   #5
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2688
mmm e se lo facessi così:

Codice:
CercaElemento(nodo r, chiave k) {
   IF (r == NULL) THEN return NULL
   IF (chiave(r) == k) THEN return r

   risultato= CercaElemento(figlio sx di r, k)
   IF (res != NULL) return res;
   risultato = CercaElemento(figlio dx di r, k)
   IF (res != NULL) return res;

   return NULL;
Così per esempio se considero l'albero in figura:



mettiamo che voglia sapere il puntatore del nodo con chiave E allora dovrebbe succedere che inizialmente ho:

1)Chiamo sul nodo A
CercaElemento(nodo A, chiave E):
risultato=CercaElemento(nodo B, chiave E):

2)Chiamo sul nodo B
CercaElemento(nodo B, chiave E):
risultato=CercaElemento(nodo D, chiave E):

3)Chiamo sul nodo D
CercaElemento(nodo D, chiave E):
risultato=CercaElemento(nodo F, chiave E)

4)Chiamo sul figlio sinistro di F che è NULL e ritorna null alla chiamata 3 a questo punto prova a chiamare sul figlio destro di F che è anch'esso null quindi torna indietro

5)Chiama sul figlio destro del nodo D che è null e restituisce null e torna indietro sul nodo B

6)2)Chiamo sul nodo B
CercaElemento(nodo B, chiave E):
risultato=CercaElemento(nodo E, chiave E): TROVATO e ritorna E al chiamnte che era la chiamata sul nodo B che a sua volta ritorna E al chiamante che era il nodo A

Ci pò stare così?

Ma secondo voi ho una sorta di handicap che tutte le volte che in qualche corso mi trovo a maneggiare ricorsioni sugli alberi mi impicco di brutto a capirle e non le manipolo mai con fluidità? :-(

Tnx
Andrea
D4rkAng3l è 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...
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...
MacBook Neo sorprende iFixit: 'Non vedev...
Venus Optics presenta due nuovi obiettiv...
AMD pubblica una guida per eseguire Open...
Tomb Raider I-III Remastered arriva su A...
X fa marcia indietro: si adeguerà...
Framework e la crisi delle memorie: terz...
Doom è ovunque: perché il ...
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: 10:53.


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