Estrutura de Dados Aula 13 - Árvores (conceito, elementos, tipos e utilizações)

leinylson 1,457 views 118 slides May 29, 2016
Slide 1
Slide 1 of 118
Slide 1
1
Slide 2
2
Slide 3
3
Slide 4
4
Slide 5
5
Slide 6
6
Slide 7
7
Slide 8
8
Slide 9
9
Slide 10
10
Slide 11
11
Slide 12
12
Slide 13
13
Slide 14
14
Slide 15
15
Slide 16
16
Slide 17
17
Slide 18
18
Slide 19
19
Slide 20
20
Slide 21
21
Slide 22
22
Slide 23
23
Slide 24
24
Slide 25
25
Slide 26
26
Slide 27
27
Slide 28
28
Slide 29
29
Slide 30
30
Slide 31
31
Slide 32
32
Slide 33
33
Slide 34
34
Slide 35
35
Slide 36
36
Slide 37
37
Slide 38
38
Slide 39
39
Slide 40
40
Slide 41
41
Slide 42
42
Slide 43
43
Slide 44
44
Slide 45
45
Slide 46
46
Slide 47
47
Slide 48
48
Slide 49
49
Slide 50
50
Slide 51
51
Slide 52
52
Slide 53
53
Slide 54
54
Slide 55
55
Slide 56
56
Slide 57
57
Slide 58
58
Slide 59
59
Slide 60
60
Slide 61
61
Slide 62
62
Slide 63
63
Slide 64
64
Slide 65
65
Slide 66
66
Slide 67
67
Slide 68
68
Slide 69
69
Slide 70
70
Slide 71
71
Slide 72
72
Slide 73
73
Slide 74
74
Slide 75
75
Slide 76
76
Slide 77
77
Slide 78
78
Slide 79
79
Slide 80
80
Slide 81
81
Slide 82
82
Slide 83
83
Slide 84
84
Slide 85
85
Slide 86
86
Slide 87
87
Slide 88
88
Slide 89
89
Slide 90
90
Slide 91
91
Slide 92
92
Slide 93
93
Slide 94
94
Slide 95
95
Slide 96
96
Slide 97
97
Slide 98
98
Slide 99
99
Slide 100
100
Slide 101
101
Slide 102
102
Slide 103
103
Slide 104
104
Slide 105
105
Slide 106
106
Slide 107
107
Slide 108
108
Slide 109
109
Slide 110
110
Slide 111
111
Slide 112
112
Slide 113
113
Slide 114
114
Slide 115
115
Slide 116
116
Slide 117
117
Slide 118
118

About This Presentation

Slides da aula de Estrutura de Daddos


Slide Content

# Estrutura de Dados #
Aula 13 –Árvores
conceito, elementos, tipos e utilizações
Prof. Leinylson Fontinele Pereira

Na aula anterior...
Listas Duplamente Encadeadas
#Propriedades
#Operações fundamentais
12:17
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Introdução
12:17 3
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

O que vamos aprender?
Árvores
#Conceito
#Componentes
#Tipos de árvores
#Onde são utilizadas?
12:17
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Vamos começar?
12:17 5
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

12:17
O que é uma Árvore?
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

12:18
Algumas Árvores... 
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

O que é uma Árvore?
12:18
Sãoumtipoespecialdegrafo
Qualquerpardevértices(nós)está
conectadoaapenasumaaresta
Grafoconexo(todosestãoconectados)
Acíclico(nãopossuiciclos)
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Formas de Representação
12:18
Grafo
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Diagrama de Venn

O que é uma Árvore?
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores
12:18
Asárvoressãoumadasestruturadedados
maisimportantesdaáreadacomputação
Utilizadaemmuitasaplicaçõesdomundoreal
Osrelacionamentoslógicosentreosdados
representamalgumadependênciadehierarquia
oucomposiçãoentreosnodos;
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores: Conceitos Básicos
12:18
As linhas que unem 2 nodos representam os relacionamentos lógicos e as
dependências de subordinação existentes entre eles
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores: Conceitos Básicos
12:18
Relacionamentosdesubordinação,formandohierarquias,podem
apresentardiferentessignificados
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Hierarquia de Especialização
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Hierarquia de Composição
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Hierarquia de Dependência
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Representação Gráfica de uma Árvore
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Terminologia
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Aterminologianãoépadronizada;
Existemnomesdiferentesparaos
mesmosconceitosemdiferentes
publicações.

Terminologia
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Raiz(root)
Todososoutrosnósdaárvoresãosubordinadosaele
Oacessoatodososnósésempreapartirdele
Nósdescendentes:
Relaçãodedependênciacomonómaisacima

Terminologia
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Casoonúmerodenóssejadiferente
dezero,existesempreumaraiz;
Casoonúmerodenóssejazero,é
denominadavazia.

Terminologia
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Terminologia
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Subárvore
Conjuntodenóssubordinadosaumúniconó,externoaestasubárvore

Terminologia
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
GraudeUmNó
Númerodesubárvoresquesãosubordinadasdiretamenteaessenó.
GraudeumaÁrvore
Éomaiorvalordentreosgrausdetodososseusnós.

Terminologia
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Terminologia
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
FolhaouTerminal(externo)
Sãoosnósdegrauzero
Nódederivação(interno)
Nósdegraumaiordoquezeroequeapresentamumasubárvore

Terminologia
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Terminologia
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
NíveldeumNó
Númerodeligaçõesentreestenóearaizdaárvoremaisum
Caminho
Sequênciadenósconsecutivosdistintosentredoisnós
ComprimentodoCaminho
Númerodeníveisentreosdoisnósmenosum

Terminologia
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Terminologia
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
AlturaouProfundidade
Éonúmerodenósdomaiorcaminhodestenóatéumde
seusdescendentes-folha
Aalturadeumaárvoreéigualaomaiorníveldeseusnós
Todososnósfolhatemaltura1.

Terminologia
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Floresta
Conjuntodezerooumaisárvoresdisjuntas
Árvoreordenada
Quandoaordemdesuassubárvoresérelevanteparaa
aplicaçãoqueestásendorepresentadaatravésdesta
estruturadedados.

Terminologia
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Binária (BinaryTree)
12:18
Quandoapresentarnomáximograu2emcadanó
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Binária (BinaryTree)
12:18
Ograudecadanópodeser0,1ou2
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Estritamente Binária
12:18
Cadanópossui0ou2subárvores
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Binária (BinaryTree)
12:18
Quandoapresentarnomáximograu2emcadanó
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Binária: Varredura esquerda‐raiz‐direita
12:18
Conhecidacomoinordertraversal,ouvarredura
central,ouvarredurainfixa.
Navarredurae‐r‐dvisitamos
1.Asubárvoreesquerdadaraiz,emordeme‐r‐d
2.Araiz
3.Finalmenteasubárvoredireitadaraiz,emordeme‐r‐d
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Binária: Varredura esquerda‐raiz‐direita
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Binária: Varredura esquerda‐raiz‐direita
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Binária: Varredura raiz‐esquerda‐direita
12:18
Conhecidacomopreordertraversal,ouvarreduraem
pré‐ordem,ouvarreduraprefixa.
Navarredurar‐e‐dvisitamos
1.Visitaaraiz
2.Percorreasubárvoreesquerdaempré-ordem
3.Percorreasubárvoredireitaempré-ordem
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Binária: Varredura esquerda‐direita‐raiz
12:18
Conhecidacomopostordertraversal,ouvarreduraem
pós‐ordem,ouvarreduraposfixa.
Navarredurae‐d‐rvisitamos
1.Percorreasubárvoreesquerdaempós-ordem
2.Percorreasubárvoredireitaempós-ordem
3.Visitaaraiz
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Binária: Tipos de Varreduras
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Binária: Contagem dos Nós
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Binárias de Busca
12:18
Considereumaárvorebinária
cujosnóstêmumcampochave
deumtipolinearmente
ordenado,ouseja,deumtipo
(comonúmeros,caracteres,e
strings)queadmite
comparações.
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Binárias de Busca
12:18
Umaárvorebináriaédebusca(emrelaçãoaocampochave)
secadanóXtemaseguintepropriedade:
AchavedeXémaiorouigualàchavedequalquernónasubárvore
esquerdadeXemenorouigualàchavedequalquernónasubárvore
direitadeX.
Emoutraspalavras,sexéumnóqualquerentãoy->chave≤
x->chave≤z->chaveparatodonóynasubárvoreesquerda
dexetodonóznasubárvoredireitadex.
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Binárias de Busca
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Binárias de Busca: versão recursiva
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Binárias de Busca: versão iterativa
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Binárias de Busca: versão iterativa
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Nopiorcaso,abuscaconsometempoproporcionalàaltura
daárvore.Seaárvoreforbalanceada,oconsumoserá
proporcionalalogn,sendononúmerodenós.
Essetempoédamesmaordemqueabuscabinárianumvetor
ordenado.

Árvores Binárias de Busca: Inserção
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Considereoseguinteproblema:Inserirumnovonó,comchavek,em
umaárvoredebusca.Éclaroqueaárvoreresultantedevetambémser
debusca.Onovonótemaformadeumafolhaavulsaepodesercriado
assim:

Árvores Binárias de Busca: Inserção
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Binárias de Busca: Remoção
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Problema:Removerumnódeumaárvoredebuscadetal
formaqueaárvorecontinuesendodebusca.
Comecemostratandodocasoemqueonóaserremovidoéa
raizdaárvore.Searaiznãotemumdosfilhos,bastaqueo
outrofilhoassumaopapelderaiz.Senão,façacomqueonó
anterioràraiznaordeme-r-dassumaopapelderaiz.

Árvores Binárias de Busca: Remoção
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Binárias de Busca: Remoção
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Binárias de Busca: Remoção
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Aexclusãodeumnóéumprocessomaiscomplexo.Paraexcluirumnódeuma
árvorebináriadebusca,hádeseconsiderartrêscasosdistintosparaaexclusão:

Árvores Binárias de Busca: Remoção
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Exclusãonafolha
Aexclusãonafolhaéamaissimples,bastaremovê-lodaárvore.

Árvores Binárias de Busca: Remoção
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Exclusãodeumnócomumfilho
Excluindo-o,ofilhosobeparaaposiçãodopai.

Árvores Binárias de Busca: Remoção
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Exclusãodeumnócomdoisfilhos
Nestecaso,pode-seoperardeduasmaneirasdiferentes.Pode-sesubstituiro
valordonóaserretiradopelovalorsucessor(onómaisàesquerdadasubárvore
direita)
Oupelovalorantecessor(onómaisàdireitadasubárvoreesquerda),
removendo-seaíonósucessor(ouantecessor).

Árvores Binárias de Busca: Remoção
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore ??????-ária
12:18
Quandoapresentarnomáximograu??????emcadanó
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Isomorfa
12:18
Quandoépossívelquesetornemcoincidentes
atravésdeumapermutaçãonaordemdas
subárvoresdeseusnós
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Balanceadas (Equilibrada)
12:18
Éaquelanaqualexisteuma
distribuiçãoequilibradaentre
osnósdaárvore
Existeumadiferençamínima
entretodasasfolhasearaiz.
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Cheia ou Completamente Balanceada
12:18
Éaquelaemquetodasasfolhasestãoauma
distânciaigualdaraiz.
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Binária Quase Completa
12:18
Adiferençadealturaentreassubárvoresde
qualquernóénomáximo1.
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores AVL
12:18
Árvorebalanceadapelaaltura
Asalturasdasduassubárvoresapartirdecada
nódiferemnomáximoemumaunidade
Asoperaçõesdebusca,inserçãoeremoçãode
elementospossuemcomplexidadeO(logn)
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores AVL
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores AVL: Rotação
12:18
Umarotaçãosimplesocorrequandoumnóestá
desbalanceadoeseufilhoestivernomesmo
sentidodainclinação,formandoumalinhareta.
Umarotação-duplaocorrequandoumnóestiver
desbalanceadoeseufilhoestiverinclinadono
sentidoinversoaopai,formandoum“joelho”.
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores AVL: Rotação
12:18
Paragarantirmosaspropriedadesdaárvore
AVLrotaçõesdevemserfeitasconformenecessário
apósoperaçõesderemoçãoouinserção.
SejaPonópai,FEofilhodaesquerda
dePeFDofilhodadireitadePpodemosdefinir4
tiposdiferentesderotação:
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores AVL: Rotação à Direita
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores AVL: Rotação à Esquerda
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores AVL: Rotação Dupla à Direita
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores AVL: Rotação Dupla à Esquerda
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Rubro Negra
12:18
Nasárvoresrubro-negras,osnósfolhasnãosão
relevantesenãocontémdados.
Estasfolhasnãoprecisamsermantidasem
memóriadecomputador,bastaapenasum
ponteiroparanuloparaidentificá-las.
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Rubro Negra
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Rubro Negra
12:18
Umnóévermelhooupreto.
Araizépreta.
Todasasfolhas(nil)sãopretas.
Ambososfilhosdetodososnósvermelhossãopretos.
Todocaminhodeumdadonóparaqualquerdeseusnós
folhasdescendentescontemomesmonúmerodenóspretos.
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Operações Básicas
12:18
Criaçãodeumaárvore
Alocaçãodasvariáveisnecessáriasparaadefiniçãodaárvore
Asdemaisoperaçõessãohabilitadasdepoisdisso
Inserçãodeumnovonó
Comoraiz
Comofolha
Comoumaposiçãointermediária
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Operações Básicas
12:18
ExclusãodeumNó
Quandonãoserealizasobreumafolha,precisareorganizaraárvore
AcessoaumNó
Destruiçãodeumaárvore
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Operações Básicas
12:18
Pai
Dadoumdeterminadonó,retornaoendereçodonó
imediatamentesuperior
Tamanho
Retornaonúmerototaldenósdeumaárvore
Altura
Retornaaalturadaárvore
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Usando Contiguidade Física
12:18
Não é intuitiva como era no caso das Listas Lineares
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Usando Contiguidade Física
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
A(3)B(1)C(0)D(4)E(0)F(0)G(0)H(0)I(0)
A(3)B(1)E(0)C(0)D(4)F(0)G(0)H(0)I(0)
1 2 3 4 5 6 7 8 9 10
1 2 3 4 5 6 7 8 9 10

Vantagens Usando Contiguidade Física
12:18
Eficienteemtermosdeespaço,
principalmentequandoograunãovaria
muito
Implementaçãoémaissimplesseexistir
limitaçãodonúmerodedescendentes.
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Desvantagens Usando Contiguidade Física
12:18
Implementaçãonãoconstituiumaboa
representaçãofísicadeárvores
Dificuldadedeseguirahierarquiaimplícita
nestasestruturasaomanipularaárvore
InserçãoeRemoçãodemorada
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Ternária Usando Contiguidade Física
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
A B C D ʎ E ʎ ʎ ʎ ʎ F G ...
1 2 3 4 5 6 7 8 9 10 11 12 13

Árvores Implementadas por Encadeamento
12:18
Oacessosedásemprepelaraiz
Osdemaisnóssãoalcançadossomentepelosendereçosdoselos
Ahierarquiadesubordinação,implícitanasárvores,fica
perfeitamenterepresentada.
Todososnósdaárvoredeveapresentaramesmaestrutura.
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Implementadas por Encadeamento
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
A
B/ / C/// D /
E/// F/// G///

Vantagens da Implementação por Encadeamento
12:18
ÉbastanteIntuitiva
InserçãoeRemoçãosãosimples,constituindo
basicamentenaatualizaçãodeendereçosnos
camposdeelodealgunsnós.
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Desvantagens da Implementação por Encadeamento
12:18
Árvorescujosnóstêmgrauvariadoapresentam
geralmentemuitoscamposdeeloociosos
OAcessoaosnóspodeserdificultadodevidoà
necessidadedeacessarqualquernóssempre
atravésdaraiz.
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Concluindo ...
12:18 87
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Exercício 1
12:18
Considereaárvorecomrepresentaçãoaninhada
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
( A ( B ) ( C ( F ( H ) ( I ) )) ( D) ( E ( G ) ) )

Exercício 2
12:18
Quantassubárvoresestaárvorecontém?
Quaisosnós-folha?
Qualograudecadanó?
Qualograudaárvore?
ListeosancestraisdosnósB,GeI.
ListeosnósdequemCéancestralpróprio.
ListeosnósdequemDédescendentepróprio.
DêoníveleaalturadonóFeA.
Qualaalturadaárvore?
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Nesta aula aprendemos...
Árvores
#Conceito
#Componentes
#Tipos de árvores
#Onde são utilizadas?
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Material: https://sites.google.com/site/leinylsonnassau
12:18
Material baseado nas aulas de:
Árvores, Cristiano Pires Martins
Árvores binárias, Paulo Feofiloff
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Na próxima aula veremos...
Técnicas de Pesquisa e Ordenação
#Conceitos
#Algoritmos
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Alguma Dúvida?
12:18
Até a próxima aula...
[email protected]

Prática 
12:18 94
As aulas práticas foram baseadas no material de
Linguagem C Descomplicada , Dr. André R. Backes.
Disponível em: https://programacaodescomplicada.wordpress.com/
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

12:18 95
Árvore Binária
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Binária: Implementação
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
EmumaÁrvoreBináriapodemosrealizarasseguintesoperações
Criaçãodaárvore
Inserçãodeumelemento
Remoçãodeumelemento
Acessoaumelemento
Destruiçãodaárvore
Essasoperaçõesdependemdotipodealocaçãodememóriausada
Estática(heap)
Dinâmica(listaencadeada)

Árvore Binária: Alocação Estática
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Usodeumarray
Usaduasfunçõespararetornaraposiçãodosfilhosàesquerdaeà
direitadeumpai

Árvore Binária: Alocação Dinâmica
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Cadanódaárvoreétratadocomoumponteiroalocadodinamicamente
amedidaqueosdadossãoinseridos

Árvore Binária: Alocação Dinâmica
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)
Paraguardaroprimeironódaárvoreutilizamosumponteiropara
ponteiro.Assim,ficafácilmudarqueméaraízdaárvore(senecessário)

Árvore Binária
12:18
ArvoreBinaria.h
Osprotótiposdasfunções
Otipodedadoarmazenadonaárvore
Oponteiroárvore
ArvoreBinaria.c
Otipodedadosárvore
Implementarassuasfunções
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

12:18 101
Definindo a Árvore
Binária
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Definindo a Árvore Binária
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

12:18 103
Criando a Árvore
Binária
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Criando a Árvore Binária
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

12:18 105
Destruindo a Árvore
Binária
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Destruindo a Árvore Binária
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Destruindo a Árvore Binária
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

12:18 108
Árvore Vazia?
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvore Vazia?
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

12:18 110
Altura da Árvore
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Altura da Árvore
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Altura da Árvore
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

12:18 113
Número de nós
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Número de nós
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Número de nós
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

12:18 116
Árvores Balanceadas
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Balanceadas
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)

Árvores Balanceadas
12:18
Estrutura de Dados: Aula 13 –Árvores (conceito, elementos, tipos e utilizações)