Esercizio Per quali valori di t l albero in figura è un B-Albero legale?
|
|
- Annabella Lillo
- 4 anni fa
- Visualizzazioni
Transcript
1 Esercizi di Algoritmi e strutture dati II: B-Alberi. A cura di: Teresa E. NARDIELLO Esercizio Per quali valori di t l albero in figura è un B-Albero legale? M D H Q T X B C F G J K L N P R S V W Y Z Per t=2 abbiamo: Se x=root 1 <= n(x) <= 3 ok! 2 <= child(x) <= 4 ok! Se x è diverso da root 1 <= n(x) <= 3 ok! 2 <= child(x) <= 4 ok! Per t=3 abbiamo: Se x=root 1 <= n(x) <= 5 ok! 2 <= child(x) <= 6 ok! Se x è diverso da root 2 <= n(x) <= 5 ok! 3 <= child(x) <= 6 ok! Per t=4 abbiamo: Se x=root 1 <= n(x) <= 7 ok! 2 <= child(x) <= 8 ok! Se x è diverso da root 3 <= n(x) <= 7 no! In questo caso c è una violazione della proprietà per cui t-1<=n(x)<=2t-1.
2 Esercizio Si mostrino tutti i B-Alberi legali con grado minimo uguale a 2 che rappresentano l insieme {1,2,3,4,5}. Se t=2 allora 1<= n(x)<=3 quindi avremo i seguenti alberi: Tali alberi sono tutti legali nel senso che rispettano la proprietà espressa sopra. Se proviamo a mettere 1 oppure 5 nella radice abbiamo: 1 5? ? In questi due casi non riusciamo a costruire i B-Alberi.
3 Esercizio Si derivi un limite superiore stretto del numero delle chiavi che possono essere memorizzate in un B-Albero di altezza h in funzione del grado minimo t. Abbiamo un B-Albero di altezza h, con grado minimo t, quello che vogliamo sapere è come possiamo limitare n, ovvero, n<=f(t)? Dalle proprietà dei B-Alberi sappiamo che: quando x è diverso dalla radice vale la seguenti proprietà t-1< n(x) <= 2t-1 quando x è uguale alla radice vale la seguente proprietà 1 <= n(root) <= 2t-1 Il numero massimo di chiavi per qualsiasi nodo è sempre 2t-1, e il numero massimo di figli per nodo è 2t. Un B-Albero massimale è allora il seguente: 2t 2t 2t 2t Come possiamo osservare dalla figura abbiamo: PROFONDITA NUMERO NODI 0 1
4 1 2t 2 (2t) 2 3 (2t) 3 Proseguendo in questo modo a profondità h avremo un numero di nodi pari a (2t) h. L albero risultante è un albero massimale in cui avremo: h Numero nodi totale = (2t) i = (2t) h+1-1/(2t-1) i=0 Numero chiavi totale = numero dei nodi totale * (2t-1) = (2t) h+1-1. Infine siamo giunti alla conclusione che n<=(2t) h+1-1. Esercizio Si descriva quale tipo di struttura di dati si otterrebbe se ogni nodo nero di un albero RB incorporasse i suoi figli rossi, fondendo i loro figli con i figli del nodo rosso. Consideriamo un esempio:
5 In tale struttura abbiamo omesso le foglie e abbiamo distinto i nodi rossi etichettandoli con la chiave in rosso, analogamente per i nodi neri. Vediamo cosa accade se ogni nodo nero dell albero RB incorpora i suoi figli rossi e fonde con i suoi figli i figli del nodo rosso: Alla fine otteniamo un B-Albero di grado t=2. Vediamo se sono verificate le proprietà dei B-Alberi: 1) Ogni nodo x è caratterizzato dai seguenti campi o attributi: a. n[x] è il numero delle chiavi memorizzate nel nodo x b. le n[x] chiavi sono memorizzate in ordine non decrescente: key 1 [x]<=key 2 [x]<=.<=key n[x] [x] c. leaf[x] è un valore di verità che è uguale a TRUE se il nodo x è una foglia, è uguale a FALSE altrimenti. Verifichiamola: 1.a: Ogni nodo x dell albero risultante dalla fusione di nodi rossi e neri contiene all inizio sicuramente una sola chiave che è quella che era presente nell albero RB di partenza, quindi n[x]=1; tale valore viene poi incrementato ogni qual volta un nodo nero incorpora i suoi figli rossi. 1.b: Possiamo facilmente avere la seconda proprietà sfruttando il fatto che un albero RB è anche un albero binario di ricerca e quindi se il nodo y(che viene incorporato da un nodo nero) apparteneva al sottoalbero sinistro del nodo x(nodo nero) allora key[y]<=key[x]. Viceversa se il nodo y apparteneva al sottoalbero destro per cui key[x]<=key[y]. Utilizzando tali proprietà degli alberi RB possiamo incorporare i nodi rossi seguendo l ordinamento delle chiavi e quindi inserendole in modo non decrescente.
6 1.c: Quando un nodo nero incorpora un nodo rosso andiamo a considerare il puntatore al figlio, se il figlio non esiste allora impostiamo il valore di leaf[nodo]=true altrimenti sarà leaf[nodo]=false. 2) Un nodo interno x contiene n[x]+1 puntatori c 1 [x],..,c n[x]+1 [x], ai suoi figli. Le foglie non hanno figli e quindi i campi c i delle foglie sono sempre indefiniti. Verifichiamola: Poiché ogni nodo di un albero RB ha al massimo due figli rossi di cui uno appartenente al sottoalbero di sinistra e l altro al sottoalbero di destra allora nel caso in cui incorporiamo due nodi rossi uno sarà indicato dal puntatore c 1 [x] e l altro da c 3 [x]. Nel caso in cui assorbiamo un solo nodo rosso allora sarà il valore della sua chiave a dirci in quale posizione sarà inserito e quindi quale indice i assumerà il puntatore c i [x]. 3) I campi key i [x] definiscono gli intervalli delle chiavi memorizzate in ciascun sottoalbero: se k i è una qualunque chiave memorizzata nel sottoalbero di radice c i [x] allora vale che k 1 <=key 1 [x]<=...<=key n[x] [x]<=key n[x]+1 [x]. Verifichiamola: Questa proprietà è una diretta conseguenza della proprietà di ordinamento parziale presente negli alberi RB che viene mantenuta e rispettata quando incorporiamo dei nodi rossi così come descritto in precedenza. 4) Tutte le foglie hanno la stessa profondità che coincide con l altezza dell albero. Verifichiamola: Ricordiamo che in ogni albero RB ogni cammino semplice da un nodo ad una foglia sua discendente ha lo stesso numero di nodi. Quindi i nodi foglia avranno tutti la stessa profondità che coincide con l altezza nera dell albero RB di partenza. 5) Il numero delle chiavi che può essere memorizzato in un nodo è limitato sia inferiormente che superiormente. Questi limiti possono essere espressi in termini di un intero t>=2 chiamato il grado minimo del B-Albero: a. Ogni nodo, con la sola eccezione della radice, deve contenere almeno t-1 chiavi. Ogni nodo interno, con la sola eccezione della radice,
7 deve contenere almeno t figli. Se l albero non è vuoto, la radice deve avere almeno una chiave. b. Ogni nodo può contenere al massimo 2t-1 chiavi. Quindi un nodo interno può avere al massimo 2t figli. Diciamo che un nodo è pieno se contiene esattamente 2t-1 chiavi. Verifichiamola: 5.a: Se il nodo x è la radice dell albero allora al massimo può avere incorporato due figli rossi, quindi avrà un numero di chiavi n[x] che sarà limitato da 1<=n[x]<=3 (1<=n[x]<=2t-1 in questo caso t=2 ok!). Se il nodo x non è la radice dell albero allora come prima abbiamo la limitazione 1<=n[x]<=3 (t-1<=n[x]<=2t-1 ok!). Tutto questo dimostra la proprietà 5.a. 5.b: Per quanto riguarda i figli di un nodo x come sopra distinguiamo il caso in cui si tratti della radice oppure no. Se il nodo x è la radice dell albero allora abbiamo la limitazione 2<= child(x) <=2t. Come prima la radice può aver assorbito uno o due figli rossi quindi avrà un numero di puntatori ai figli che sarà pari a n[x]+1, nel nostro caso 2<= child(x) <=4 in cui t=2 ok!. Se il nodo x non è la radice dell albero il discorso è analogo solo che questa volta la limitazione è t<= child(x) <=2t e nel nostro caso abbiamo 2<= child(x) <=4 ok! Anche la proprietà 5.b è rispettata. Esercizio Si spieghi come trovare la chiave più piccola presente in un B-Albero e come trovare il predecessore di una determinata chiave memorizzata in un B-Albero. Per trovare la chiave più piccola in un B-Albero scendiamo sempre a sinistra e nell ultimo nodo consideriamo la prima chiave a sinistra. Per trovare il predecessore di una determinata chiave useremo come esempio l albero dell esercizio precedente. Supponiamo di avere come parametri della procedura PRED(x,i) in cui la variabile x indica il nodo in cui si trova la chiave k di cui vogliamo conoscere il predecessore e la variabile i che indica la posizione della chiave k all interno del nodo x in modo tale che key(x)=k. Distinguiamo vari casi:
8 1)Se leaf(x)=f vuol dire che il nodo x non è una foglia, allora per trovare il predecessore di k, avendo PRED(x,i) faremo max(c i (x)), ovvero, andiamo a trovare il massimo del sottoalbero di sinistra. 2)Se leaf(x)=t vuol dire che il nodo x è una foglia e dobbiamo andare a distinguere vari sottocasi: Se i è diverso da 1 allora il predecessore sarà la chiave key i-1 (x). (Esempio:nell albero precedente il predecessore di 38 è 35) Se i è uguale a 1, allora il nodo x sarà figlio di qualche nodo y tale che x=c j (y), quindi esaminiamo il valore di j. 1. Se j>1 allora il predecessore sarà nella chiave key j-1 (y). (Esempio:nell albero precedente il predecessore di 35 è 30 infatti i=1, j=2 => j>i allora Pred(35)=key j-1 (y)=key 1 (y)=30) 2. Se j è uguale a 1 come prima andiamo a vedere nel padre del nodo x se troviamo il predecessore. Quando i=1 e j=1 allora il predecessore si trova risalendo nell albero fino ad incontrare un nodo y tale che c k (y) abbia un indice k diverso da 1 in modo tale che key k-1 (y) è il predecessore cercato. (Esempio: nell albero di prima il predecessore di 3 non esiste, in questo caso i=1, j=1 ma x è l ultimo nodo a sinistra, il che significa che la prima chiave è il minimo dell albero.) (Esempio: il predecessore di 28 nell albero di prima si trova risalendo fino alla radice che contiene la chiave 26). Esercizio Supponiamo che la procedura B-TREE-SEARCH sia realizzata in modo tale da utilizzare in ogni nodo la ricerca binaria invece della ricerca lineare. Si mostri che questa modifica permette di ottenere un tempo di CPU di O(lg n) indipendentemente dalla scelta di t in funzione del valore di n. Nel caso della ricerca binaria avremo che il tempo di CPU è: O(log t n * log 2 t) = O(log 2 n) perché log t n = log 2 n/log 2 t.
9 Esercizio Si mostri il risultato dell eliminazione delle chiavi C,P,V dal seguente albero: E L P T X A C J K N O Q R S U V Y Z x Si osservi che t=3 e si ricordi che la funzione DELETE viene chiamata su un nodo solo se il numero delle chiavi è almeno uguale al grado minimo. DELETE(root,C) Poiché il nodo x a cui appartiene la chiave C ha t-1 chiavi e nessun fratello gliele può prestare allora eseguiamo una fusione. Per prima cosa facciamo scendere la chiave E nel nodo x, effettuiamo una fusione col nodo fratello di x e poi invochiamo la funzione DELETE(x,C). L P T X A E J K N O Q R S z U V Y Z DELETE(root,P) Il nodo in cui è presente il successore di P ha un numero di chiavi sufficienti per poter chiamare la procedura quindi chiamiamo la funzione DELETE sul nodo z a cui appartiene la chiave Q=SUCC(P); in seguito metteremo nel nodo root al posto della chiave P la chiave Q.
10 L Q T X A E J K N O R S U V Y Z DELETE(root,V) Nel nodo a cui appartiene V non ci sono abbastanza chiavi e nessuno dei fratelli del nodo è in grado di prestargliele quindi facciamo una fusione tra i nodi RS e UV; facciamo scendere la chiave T dalla radice nel nodo in cui è presente V ed infine invochiamo la procedura DELETE(y,V) dove y è il nuovo nodo ottenuto dalla fusione. Fusione tra i nodi RS e UV con relativo inserimento della chiave T: L Q X A E J K N O R S T U V Y Z y DELETE(y,V) L Q X A E J K N O R S T U Y Z
B-Alberi Esercitazioni
B-Alberi Esercitazioni Introduzione B-Trees: alberi bilanciati di ricerca progettati per essere memorizzati su dischi magnetici. Dischi magnetici molto più lenti delle memorie ad accesso casuale. La misura
DettagliAlgoritmi e Strutture Dati
Alberi Rosso-Neri (RB-Trees) Maria Rita Di Berardini, Emanuela Merelli 1 1 Dipartimento di Matematica e Informatica Università di Camerino A.A. 2007/08 Alberi Rosso-Neri: definizione Un albero rosso-nero
DettagliAlgoritmi e Strutture Dati
Alberi Rosso-Neri (RB-Trees) Maria Rita Di Berardini, Emanuela Merelli 1 1 Dipartimento di Matematica e Informatica Università di Camerino Alberi Rosso-Neri Altezza nera di un red-black tree Un albero
DettagliDipartimento di Elettronica, Informazione e Bioingegneria API 2013/4
Dipartimento di Elettronica, Informazione e Bioingegneria API 2013/4 Bilanciamento negli alberi di ricerca @ G. Gini 2013 Dizionari Dizionario Insieme dinamico che implementa le seguenti funzionalità Cerca
Dettaglid. Cancellazione del valore 5 e. Inserimento del valore 1
Esercizio1 Si consideri un albero binario non vuoto in cui a ciascun nodo v è associato un numero reale v.val. Scrivere un algoritmo che, dato in input l'albero T e un numero reale x, restituisce true
Dettaglialgoritmi e strutture di dati
algoritmi e strutture di dati alberi rosso-neri m.patrignani contenuto definizione di alberi rosso-neri proprietà degli alberi rosso-neri complessità delle operazioni elementari rotazioni inserimenti e
DettagliAlberi Rosso-Neri: definizione
Alberi Rosso-Neri: definizione Altezza di un red-black tree Un albero Rosso Nero (Red Black Tree, RB tree) èunalbero binario di ricerca in cui ad ogni nodo viene associato un colore rosso o nero Ogni nodo
DettagliAlgoritmi e Strutture Dati
Alberi Rosso-Neri (RB-Trees) Maria Rita Di Berardini, Emanuela Merelli 1 1 Dipartimento di Matematica e Informatica Università di Camerino Alberi Rosso-Neri Definizione Altezza nera di un red-black tree
DettagliIn questa lezione Alberi binari di ricerca
In questa lezione Alberi binari di ricerca!1 Dizionari Un dizionario è una struttura dati costituita da un insieme con le operazioni di inserimento, cancellazione e verifica di appartenenza di un elemento.
DettagliNote per la Lezione 4 Ugo Vaccaro
Progettazione di Algoritmi Anno Accademico 2016 2017 Note per la Lezione 4 Ugo Vaccaro Ripasso di nozioni su Alberi Ricordiamo che gli alberi rappresentano una generalizzazione delle liste, nel senso che
DettagliESERCIZI DI ALGORITMI E STRUTTURE DATI 2 Parte 2. Livio Colussi Dipartimento di Matematica Pura ed Applicata Università di Padova
ESERCIZI DI ALGORITMI E STRUTTURE DATI 2 Parte 2 Livio Colussi Dipartimento di Matematica Pura ed Applicata Università di Padova 19 maggio 2006 2 Esercizio 18 Perché in un B-albero non possiamo avere grado
DettagliAlberi binari: definizione e alcune proprietà
Alberi binari: definizione e alcune proprietà Alberi binari Un albero binario è un albero con radice in cui ogni nodo ha al più due figli. In maniera più formale: Definizione. (Alberi binari) Un albero
DettagliAlberi binari di ricerca
Alberi binari di ricerca Gli alberi binari di ricerca sono ottime strutture dati per memorizzare coppie di elementi (k, e) chiave elemento di un dizionario. Un albero binario di ricerca T è un albero binario
DettagliAlberi binari di ricerca
Alberi binari di ricerca Ilaria Castelli castelli@dii.unisi.it Università degli Studi di Siena Dipartimento di Ingegneria dell Informazione A.A. 2009/20010 I. Castelli Alberi binari di ricerca, A.A. 2009/20010
DettagliAlgoritmi e Strutture Dati
Algoritmi e Strutture Dati Alberi di ricerca Domenico Fabio Savo 1 Dizionari Gli alberi di ricerca sono usati per realizzare in modo efficiente il tipo di dato Dizionario 2 Alberi binari di ricerca (BST
DettagliIndici multilivello dinamici (B-alberi e B + -alberi) Alberi di ricerca - 1. Un esempio. Alberi di ricerca - 3. Alberi di ricerca - 2
INDICI MULTILIVELLO DINAMICI Indici multilivello dinamici (B-alberi e B + -alberi) Gli indici multilivello dinamici (B-alberi e B + -alberi) sono casi speciali di strutture ad albero. Un albero è formato
DettagliEsercizi su ABR. Prof. E. Fachini - Intr. Alg.!1
Esercizi su ABR Confronto proprietà ABR e Max-Heap. Proprietà del cammino radice-foglia individuato da una ricerca. Fusione di due ABR. Il successivo calcolato dalla radice Costruzione di un ABR bilanciato
DettagliAlberi binari e alberi binari di ricerca
Università degli studi di Milano Dipartimento di Informatica Laboratorio di algoritmi e strutture dati Corso di laurea in Informatica Alberi Un albero è una collezione non vuota di: nodi con nome e informazioni
DettagliAlberi binari e alberi binari di ricerca
Alberi binari e alberi binari di ricerca Violetta Lonati Università degli studi di Milano Dipartimento di Informatica Laboratorio di algoritmi e strutture dati Corso di laurea in Informatica giovedì 9
DettagliAlberi Binari di Ricerca
Alberi Binari di Ricerca Prof. G. M. Farinella gfarinella@dmi.unict.it www.dmi.unict.it/farinella Riferimenti Bibliografici Cormen T.H., Leiserson C.E., Rivest R.L Introduction to Algorithms, Third Edition,
DettagliProblemi di ordinamento
Problemi di ordinamento Input: una sequenza di n numeri a 1, a 2,..., a n ; Output: una permutazione a 1, a 2,..., a n di a 1, a 2,..., a n tale che a 1 a 2... a n. Generalmente, la sequenza è rappresentata
DettagliFondamenti teorici e programmazione
Fondamenti teorici e programmazione FTP(A) - modb Lezione 9 di ricerca binaria F.Bonchi Dip.to Informatica Fondamenti teorici e programmazione (A) - modb a.a. 2018/19 pag. 1 liberi Un albero libero è un
Dettagli23/10/2016. gli alberi. alcune definizioni. un esempio. LABORATORIO DI PROGRAMMAZIONE 2 Corso di laurea in matematica.
gli alberi Un albero è una struttura dati NON LINEARE organizzata gerarchicamente. LABORATORIO DI PROGRAMMAZIONE 2 Corso di laurea in matematica È costituito da un insieme di nodi collegati tra di loro:
DettagliAlberi Binari di Ricerca e Alberi Rosso-Neri
Alberi Binari di Ricerca e Alberi Rosso-Neri Obiettivi Studiare strutture dati che consentano di effettuare in modo efficiente le operazioni di Minimo e massimo Successore Inserimento e cancellazione Ricerca
DettagliAlgoritmi e Strutture Dati. Capitolo 6 Il problema del dizionario
Algoritmi e Strutture Dati Capitolo 6 Il problema del dizionario Il tipo dato Dizionario Suppongo sempre che mi venga dato un riferimento diretto all elemento da cancellare Applicazioni: gestione archivi
DettagliAlgoritmi e Strutture di Dati
Algoritmi e Strutture di Dati Alberi rosso-neri m.patrignani Contenuto Definizione di alberi rosso-neri Proprietà degli alberi rosso-neri Complessità delle operazioni elementari Rotazioni Inserimenti e
DettagliAlgoritmi e Strutture Dati & Laboratorio di Algoritmi e Programmazione
Algoritmi e Strutture Dati & Laboratorio di Algoritmi e Programmazione Appello del 24 Gennaio 2007 Esercizio 1 (ASD) 1. Sia T (n) = T (n/6) + T (n/3) + Θ(n). Considerare ciascuna delle seguenti affermazioni
DettagliAlgoritmi, Strutture Dati e Programmi. UD 3.d: Strutture Dati Dinamiche Alberi
Algoritmi, Strutture Dati e Programmi : Strutture Dati Dinamiche Alberi Prof. Alberto Postiglione AA 2007-2008 ALBERO BINARIO DI RICERCA Dispense, cap. 3.3.3 1 Albero Binario di Ricerca Struttura bidimensionale.
DettagliAlberi binari e alberi binari di ricerca
Alberi binari e alberi binari di ricerca Violetta Lonati Università degli studi di Milano Dipartimento di Scienze dell Informazione Laboratorio di algoritmi e strutture dati Corso di laurea in Informatica
DettagliLE STRUTTURE DATI DINAMICHE: GLI ALBERI. Cosimo Laneve
LE STRUTTURE DATI DINAMICHE: GLI ALBERI Cosimo Laneve 1 argomenti 1. definizione di alberi e nozioni relative 2. implementazione degli alberi, creazione, visita 3. algoritmo di visita iterativa e sua implementazione
DettagliAlberi rosso-neri. Le operazioni sugli alberi binari di ricerca hanno complessità proporzionale all altezza h dell albero.
Alberi rosso-neri Le operazioni sugli alberi binari di ricerca hanno complessità proporzionale all altezza h dell albero. Gli alberi rosso-neri sono alberi binari di ricerca in cui le operazioni Insert
DettagliMulti-way search trees
Multi-way search trees GT. 10.4 1 Argomenti Multi-way search trees Multi-way searching 9 (2,4) Trees 2 5 7 10 14 2 1 Alberi Binari di Ricerca Bilanciati n numero di chiavi (entry(key,elem)) AVL tree log(
DettagliAlberi rosso neri. API a.a. 2013/2014 Gennaio 23, 2014 Flavio Mutti, PhD
Alberi rosso neri API a.a. 2013/2014 Gennaio 23, 2014 Flavio Mutti, PhD 2 Sommario Definizione Operazione di rotazione Inserimento Cancellazione Temi d esame 3 Introduzione Un albero rosso-nero è un albero
DettagliDizionari. Realizzazione con alberi binari di ricerca. Alberi rosso-neri. Ugo de' Liguoro - Algoritmi e Seprimentazioni 03/04 Lez.
Dizionari Realizzazione con alberi binari di ricerca. Alberi rosso-neri. Dizionari con gli alberi Astro, Dado, Lana, Mela, Tasto,Vela, Zappa Mela Astro Tasto Zappa Alberi binari di ricerca Gli alberi binari
DettagliMoltiplicazione veloce di interi
Moltiplicazione veloce di interi Ogni numero intero w di n cifre può essere scritto come 10 n/2 w s + w d w s indica il numero formato dalle n/2 cifre più significative di w w d denota il numero formato
DettagliLaboratorio 26 Aprile 2012
Laboratorio 26 Aprile 2012 Albero binario di ricerca: Ricerca Scrivere un programma che legga da tastiera una sequenza di n interi distinti e li inserisca in un albero binario di ricerca (senza ribilanciamento)
DettagliAlberi rosso-neri. Oltre ad essere alberi binari di ricerca, gli alberi rosso-neri soddisfano le seguenti proprietà:
Alberi rosso-neri Gli alberi rosso-neri sono alberi binari di ricerca in cui le operaioni Insert e Delete sono opportunamente modificate in modo tale da garantire un altea dell albero h = O(log n). A tale
DettagliRISOLUZIONE IN LOGICA PROPOSIZIONALE. Giovanna D Agostino Dipartimento di Matemaica e Informatica, Università di Udine
RISOLUZIONE IN LOGICA PROPOSIZIONALE Giovanna D Agostino Dipartimento di Matemaica e Informatica, Università di Udine 1. Risoluzione Definitione 1.1. Un letterale l è una variabile proposizionale (letterale
DettagliAlberi binari. Alberi binari di ricerca
Alberi binari Alberi binari Alberi binari di ricerca Cause: Inserimenti Sbilanciamento Cancellazioni Alberi binari Alberi binari di ricerca Alberi binari di ricerca bilanciati Alberi binari Alberi binari
DettagliAlberi. CORDA Informatica. A. Ferrari. Testi da. Marco Bernardo Edoardo Bontà. Dispense del Corso di. Algoritmi e Strutture Dati
Alberi CORDA Informatica A. Ferrari Testi da Marco Bernardo Edoardo Bontà Dispense del Corso di Algoritmi e Strutture Dati Albero - definizione Albero Figli, fratelli, nodi, foglie Grado, livello, altezza,
DettagliAlberi binari. Alberi Albero binario Heap tree
Alberi binari Alberi Albero binario eap tree Albero Ogni nodo può avere un numero arbitrario di figli Un nodo senza figli viene detto foglia siste un nodo particolare chiamato radice, tutti gli altri hanno
DettagliUniversità degli Studi di L Aquila Facoltà di Scienze M.F.N. Corso di Laurea in Informatica. Modulo di Laboratorio di Algoritmi e Strutture Dati
Università degli Studi di L Aquila Facoltà di Scienze M.F.N. Corso di Laurea in Informatica Modulo di Laboratorio di Algoritmi e Strutture Dati Alberi binari Giovanna Melideo melideo@di.univaq.it 1 Alberi
DettagliADT Dizionario. Ordered search table. Supponiamo che sia definita una relazione d'ordine totale sulle chiavi del dizionario D:
Ordered search table Supponiamo che sia definita una relazione d'ordine totale sulle chiavi del dizionario D: possiamo memorizzare le entrate di D in un array list S in ordine non decrescente di chiavi:
DettagliIn questa lezione Alberi binari di ricerca: la cancellazione
In questa leione Alberi binari di ricerca: la cancellaione 1 L algoritmo di Hibbard per cancellare (1962) Sia il nodo da cancellare: 1) è una foglia: si rimuove 2) ha un solo figlio x: si rende x figlio
DettagliGianpiero Cabodi e Paolo Camurati Dip. Automatica e Informatica Politecnico di Torino. Prestazioni dei BST
Gli alberi bilanciati Gianpiero abodi e Paolo amurati Dip. utomatica e nformatica Politecnico di Torino Prestazioni dei BT Prestazioni variabili da: logaritmiche: caso migliore, albero bilanciato lineari:
DettagliAlgoritmi e Strutture di Dati
Algoritmi e Strutture di Dati Alberi radicati m.patrignani Nota di copyright queste slides sono protette dalle leggi sul copyright il titolo ed il copyright relativi alle slides (inclusi, ma non limitatamente,
DettagliDatabases. Architettura di un DBMS: Struttura ad indice per i files, B + -Trees
Databases Architettura di un DBMS: Struttura ad indice per i files, B + -Trees Indici Un indice consiste di coppie e supporta l efficiente recupero di tutte le etichette con chiave
DettagliAlberi binari di ricerca
Alberi binari di ricerca Definizione Un albero si dice albero binario di ricerca è un albero binario in cui: - Ogni nodo è caratterizzato un valore chiamato chiave - L insieme delle chiavi è totalmente
DettagliEsercizi su alberi binari
Esercizi su alberi binari Esercizi svolti: Determinazione nodi contenti verifica completezza verifica quasi completezza lunghezza del cammino interno determinazione ultima foglia in un quasi completo verifica
DettagliAlberi Binari di Ricerca
Alberi Binari di Ricerca Algoritmi su gli alberi binari: visite Dato un puntatore alla radice di un albero vogliamo scandire in modo sistematico tutti i nodi di tale albero In una lista abbiamo una unica
DettagliB-alberi. Strutture dati avanzate
Strutture dati avanzate Strutture dati avanzate B-alberi B-alberi Vedremo alcune strutture dati che permettono di eseguire in modo particolarmente efficiente un determinato insieme di operazioni. Ognuna
DettagliAlberi e alberi binari I Un albero è un caso particolare di grafo
Alberi e alberi binari I Un albero è un caso particolare di grafo I I I I È costituito da un insieme di nodi collegati tra di loro mediante archi Gli archi sono orientati (ogni arco esce da un nodo origine
DettagliIl numero dei nodi al livello i è 1, per 0 i altezza L altezza h di un albero completamente sbilanciato con n nodi è h = n-1
alberi completamente sbilanciati Il numero dei nodi al livello i è 1, per 0 i altezza L altezza h di un albero completamente sbilanciato con n nodi è h = n-1 1 Un albero completamente bilanciato o pieno
DettagliAlberi e alberi binari I Un albero è un caso particolare di grafo
Alberi e alberi binari Un albero è un caso particolare di grafo È costituito da un insieme di nodi collegati tra di loro mediante archi Gli archi sono orientati (ogni arco esce da un nodo origine ed entra
DettagliEspressioni aritmetiche
Espressioni aritmetiche Consideriamo espressioni costruite a partire da variabili e costanti intere mediante applicazione delle operazioni di somma, sottrazione, prodotto e divisione (intera). Ad esempio:
DettagliDizionari. Dizionari con gli alberi. Alberi binari di ricerca. Realizzazione con alberi binari di ricerca. Alberi rosso-neri.
Dizionari Realizzazione con alberi binari di ricerca. Alberi rosso-neri. Dizionari con gli alberi Astro, Dado, Lana, Mela, Tasto,Vela, Zappa Astro Mela Tasto Zappa Alberi binari di ricerca Gli alberi binari
DettagliAlberi ed Alberi Binari
Alberi ed Alberi Binari Il tipo di dato Albero Un albero è una struttura di data organizzata gerarchicamente. È costituito da un insieme di nodi collegati tra di loro: ogni nodo contiene dell informazione,
DettagliHeap e code di priorità
Heap e code di priorità Violetta Lonati Università degli studi di Milano Dipartimento di Scienze dell Informazione Laboratorio di algoritmi e strutture dati Corso di laurea in Informatica AA 2009/2010
DettagliEsercizi BST - AVL. E. Fachini
Esercizi BST - AVL. Verifica che un ABR è un AVL 2. verifica bilanciamento in altezza di un ABR 3. Costruzione alberi di Fibonacci 4. Calcolo altezza albero AVL in O(lg n) 5. split di una ABR intorno a
DettagliAlberi ed Alberi Binari di Ricerca
Alberi ed Alberi Binari di Ricerca Il tipo di dato Albero Un albero è una struttura di data organizzata gerarchicamente. È costituito da un insieme di nodi collegati tra di loro: ogni nodo contiene dell
DettagliAlgoritmi e Strutture Dati. HeapSort
Algoritmi e Strutture Dati HeapSort Selection Sort: intuizioni L algoritmo Selection-Sort scandisce tutti gli elementi dell array a partire dall ultimo elemento fino all inizio e ad ogni iterazione: Viene
Dettaglialberi completamente sbilanciati
alberi completamente sbilanciati Il numero dei nodi al livello i è 1, per 0 i altezza L altezza h di un albero completamente sbilanciato con n nodi è h = n-1 1 Un albero completamente bilanciato o pieno
DettagliEsercitazione 6. Alberi binari di ricerca
Esercitazione 6 Alberi binari di ricerca Struttura base Rappresentabile attraverso una struttura dati concatenata in cui ogni nodo è un oggetto di tipo struttura Ogni nodo contiene: campo chiave (key)
DettagliAlberi. Gli alberi sono una generalizzazione delle liste che consente di modellare delle strutture gerarchiche come questa: Largo. Fosco.
Alberi Alberi Gli alberi sono una generalizzazione delle liste che consente di modellare delle strutture gerarchiche come questa: Largo Fosco Dora Drogo Frodo Dudo Daisy Alberi Gli alberi sono una generalizzazione
DettagliEsercizio 1. E vero che in un AVL il minimo si trova in una foglia o nel penultimo livello? FB = -1. livello 0 FB = -1. livello 1 FB = -1.
Esercizio 1 E vero che in un AVL il minimo si trova in una foglia o nel penultimo livello? FB = -1 livello 0 FB = -1 FB = -1 livello 1 FB = -1 livello 2 livello 3 L altezza è 3, il minimo si trova nel
DettagliAlberi. Se x è il genitore di y, allora y è un figlio di x. Un albero binario è un albero in cui ogni nodo ha al massimo due figli.
Alberi Un albero è un insieme di oggetti, chiamati nodi, su cui è definita una relazione binaria G(x, y) che leggiamo x è genitore di y tale che: 1. esiste un unico nodo, chiamato radice, che non ha genitori;
DettagliProgettazione di algoritmi
Progettazione di algoritmi Discussione dell'esercizio [vincoli] Prima di tutto rappresentiamo il problema con un grafo G: i nodi sono le n lavorazioni L 1, L 2,, L n, e tra due nodi L h, L k c'è un arco
Dettagliliste ogni nodo ha un successore, tranne l ultimo della lista che ne ha zero; alberi binari ogni nodo ha zero, uno oppure due figli
Alberi generali Gli alberi visti fino a questo momento erano insiemi di nodi collegati fra di loro, in cui ogni nodo poteva avere al massimo due figli. Negli alberi generali, ogni nodo può avere un numero
DettagliAlberi. Gli alberi sono una generalizzazione delle liste che consente di modellare delle strutture gerarchiche come questa: Largo. Fosco.
Alberi Alberi Gli alberi sono una generalizzazione delle liste che consente di modellare delle strutture gerarchiche come questa: Largo Fosco Dora Drogo Dudo Frodo Daisy Alberi Gli alberi sono una generalizzazione
DettagliIntroduzione agli algoritmi Prova di esame del 19/9/2016 Prof.sse E. Fachini - R. Petreschi. Parte prima
Introduzione agli algoritmi Prova di esame del 19/9/2016 Prof.sse E. Fachini - R. Petreschi Parte prima 1) Si dimostri il teorema sulla limitazione inferiore per il tempo asintotico di esecuzione nel caso
DettagliIn questa lezione. Heap binario heapsort. [CLRS10] cap. 6, par Prof. E. Fachini - Intr. Alg.
In questa lezione Heap binario heapsort [CLRS10] cap. 6, par. 6.1-6.4!1 Heap binari Un heap binario è una struttura dati consistente di un array visto come un albero binario. A= 5 60 65 30 50 18 40 25
DettagliAlgoritmi e Strutture Dati
Maria Rita Di Berardini, Emanuela Merelli Scuola di Scienze e Tecnologie Università di Camerino Definizione (bilanciamento in altezza): un albero è bilanciato in altezza se le altezze dei sottoalberi sinistro
DettagliRicerca con una chiave k Assumiamo l esistenza di un descrittore albero con i campi: albero.radice (=null per l albero vuoto) albero.dimensione (=0 pe
Ricerca con una chiave k Assumiamo l esistenza di un descrittore albero con i campi: albero.radice (=null per l albero vuoto) albero.dimensione (=0 per l albero vuoto) La funzione Ricerca prende in input
Dettagliricerca di un elemento, verifica dell appartenenza di un elemento
Alberi Binari di Ricerca Gli alberi binari di ricerca (o, alberi di ricerca binaria) sono strutture dati che consentono, su un insieme di elementi con un ordine totale le operazioni di: ricerca di un elemento,
DettagliRichiami di matematica discreta: grafi e alberi. Paolo Camurati Dip. Automatica e Informatica Politecnico di Torino
Richiami di matematica discreta: grafi e alberi Paolo Camurati Dip. Automatica e Informatica Politecnico di Torino Grafi Definizione: G = (V,E) V: insieme finito di vertici E: insieme finito di archi,
DettagliALBERI : introduzione SOMMARIO ALBERI ALBERI. ALBERI: introduzione ALBERI BINARI: introduzione VISITE RICORSIVE DI ALBERI
SOMMARIO ALBERI: introduzione ALBERI BINARI: introduzione VISITE RICORSIVE DI ALBERI Dimensione e Altezza ALBERI BINARI DI RICERCA (BST) Introduzione Ricerca, inserimento e cancellazione Implementazione
DettagliINFORMATICA 3 Prof.ssa Sara Comai
INFORMATICA 3 Prof.ssa Sara Comai ESERCIZI SESSIONE LIVE 3 Complessità, liste e alberi Ing. Paola Spoletini, Sara Comai. Complessità Si determini l ordine di grandezza Q della complessità temporale di
DettagliAlgoritmi e Strutture Dati. Alberi Bilanciati: Alberi Red-Black
Algoritmi e Strutture Dati Alberi Bilanciati: Alberi Red-Black Alberi bilanciati di ricerca Gli alberi binari di ricerca sono semplici da gestire (inserimenti e cancellazioni facili da implementare) ma
DettagliGli heap. Sommario. Algoritmi e Programmazione Avanzata. Fulvio CORNO - Matteo SONZA REORDA Dip. Automatica e Informatica Politecnico di Torino
Gli heap Fulvio CORNO - Matteo SONZA REORDA Dip. Automatica e Informatica Politecnico di Torino 1 a.a. 2001/2002 Sommario Gli heap L algoritmo Heapsort Le code con priorità. 2 a.a. 2001/2002 Politecnico
DettagliSuffix Trees. Docente: Nicolò Cesa-Bianchi versione 21 settembre 2017
Complementi di Algoritmi e Strutture Dati Suffix Trees Docente: Nicolò Cesa-Bianchi versione 21 settembre 2017 In generale, possiamo trovare tutte le occorrenze di un pattern y in un testo x in tempo O(
DettagliProgrammazione Greedy I codici di Huffman
Programmazione Greedy I codici di Huffman Codifica dell informazione La rappresentazione ordinaria dell informazione prevede l impiego di un numero costante di bit; per esempio ad ogni carattere del codice
DettagliAlgoritmo di ordinamento sul posto che ha tempo di esecuzione :
QuickSort Algoritmo di ordinamento sul posto che ha tempo di esecuzione : O(n2 ) nel caso peggiore O(n log n) nel caso medio Nonostante le cattive prestazioni nel caso peggiore, rimane il miglior algoritmo
DettagliEsercitazione 2. Progettare un algoritmo che risolva tale problema in tempo O( E + V log V ).
Esercitazione 2 Problema 4: Dato un grafo G = (V, E) con pesi positivi sugli archi ed un insieme di k centri C = {c 1, c 2, c k } V, si richiede di partizionare l insieme V in k insiemi V 1, V 2, V k in
DettagliAlberi due-tre e alberi B
Università di Torino Facoltà di Scienze MFN Corso di Studi in Informatica Curriculum SR (Sistemi e Reti) Basi di Dati e Algoritmi, a.a. 2006-07 prof. Elio Giovannetti CREDITS Alcune slides con disegni
DettagliAlberi binari (radicati e ordinati) della radice Il padre del nodo 5 e del nodo 3
Alberi binari (radicati e ordinati) Il figlio sinistro della radice Il padre del nodo 5 e del nodo 3 4 3 Il figlio sinistro del nodo 2 2 5 1 6 7 8 9 La radice Il figlio destro della radice una foglia Figlio
DettagliAlberi di ricerca. Dizionari. Definizione. Alberi binari di ricerca (BST = binary search tree) Algoritmi e Strutture Dati
Algoritmi e Strutture Dati Dizionari Gli alberi di ricerca sono usati per realizzare in modo efficiente il tipo di dato dizionario Alberi di ricerca Basato su materiale di C. Demetrescu, I. Finocchi, G.F.
DettagliUn albero completamente bilanciato o pieno (full) alberi completamente sbilanciati. Un albero binario completo
alberi completamente sbilanciati Un albero completamente bilanciato o pieno (full) Definizione: Un albero è pieno se tutte le foglie sono sullo stesso livello e ogni nodo non foglia ha due figli. Il numero
DettagliEsercizi proposti Risolvere i problemi seguenti su espressioni rappresentate come alberi binari, mediante la dichiarazione di tipo
Esercizi proposti 8 INDICZIONI DI CRTTERE GENERLE: Quando scrivete una funzione che ne utilizza una ausiliaria, chiedetevi sempre se l ausiliaria è necessaria, ricordando che è utile quando: (a) servono
DettagliParallel sorting. Algoritmi Avanzati. Davide Lo Re
Parallel sorting Algoritmi Avanzati Davide Lo Re Indice Richiami Idea Descrizione Illustrazione Fase 1: Costruzione delle strutture dati Fase 1.1 Fase 1.2 Fase 2: Merge Analisi Costo Algoritmo di Cole
DettagliAlgoritmi e strutture dati
Algoritmi e Strutture Dati Alberi di ricerca Dizionari Gli alberi di ricerca sono usati per realizzare in modo efficiente il tipo di dato dizionario 2 Alberi binari di ricerca (BST = binary search tree)
DettagliAlgoritmi e Strutture Dati
Heap Maria Rita Di Berardini, Emanuela Merelli 1 1 Dipartimento di Matematica e Informatica Università di Camerino A.A. 2006/07 Heap Heap binari: definizione Un heap binario è una struttura dati composta
DettagliABR di altezza logaritmica
R di altezza logaritmica Esistono vari criteri di bilanciamento di alberi binari di ricerca ce ne garantiscono l altezza logaritmica. iamiamo bilanciato ogni albero binario di altezza logaritmica nel numero
DettagliAlgoritmi e Strutture Dati
Heap Maria Rita Di Berardini, Emanuela Merelli 1 1 Dipartimento di Matematica e Informatica Università di Camerino 6 novembre 2008 Heap binari: definizione Un heap binario è una albero binario quasi completo
DettagliAlgoritmi e Principi dell'informatica Seconda Prova in Itinere - 14 Febbraio 2014
Algoritmi e Principi dell'informatica Seconda Prova in Itinere - 14 Febbraio 2014 Nome..Cognome.Matr. Laureando Avvisi importanti Il tempo a disposizione è di 1 ora e 30 minuti. Se non verranno risolti
Dettaglicome segue: data una collezione C di elementi e una un elemento che verifica la proprietà P
Problemi di Ricerca Carla Binucci e Walter Didimo Il problema della Ricerca In generale, il Problema della Ricerca è definito come segue: data una collezione C di elementi e una proprietà P, determinare
DettagliGLI ALBERI BINARI DI RICERCA. Cosimo Laneve
GLI ALBERI BINARI DI RICERCA Cosimo Laneve argomenti 1. alberi binari di ricerca 2. la ricerca di elementi e la complessità computazionale 3. operazione di cancellazione di elementi 4. esempi/esercizi
Dettagli