| 
 | |||||||
| 
 | 
|  | 
|  | 
|  | Strumenti | 
|  25-06-2008, 16:10 | #1 | 
| Bannato Iscritto dal: Mar 2004 Città: Roma 
					Messaggi: 2682
				 | 
				
				[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)
}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 | 
|   |   | 
|  25-06-2008, 18:30 | #2 | 
| Senior Member 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 | 
|   |   | 
|  25-06-2008, 18:36 | #3 | 
| Senior Member Iscritto dal: May 2004 Città: Napoli 
					Messaggi: 773
				 | 
		
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 | 
|   |   | 
|  25-06-2008, 19:19 | #4 | |
| Senior Member Iscritto dal: Jun 2002 Città: Dublin 
					Messaggi: 5989
				 | Quote: 
 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! | |
|   |   | 
|  25-06-2008, 19:25 | #5 | 
| Bannato Iscritto dal: Mar 2004 Città: Roma 
					Messaggi: 2682
				 | 
		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; 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 | 
|   |   | 
|   | 
| Strumenti | |
| 
 | 
 | 
Tutti gli orari sono GMT +1. Ora sono le: 19:55.









 
		 
		 
		 
		








 
  
 



 
                        
                        










