-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
5 changed files
with
64 additions
and
0 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
# Filas de prioridade - Heap | ||
|
||
## Introdução | ||
|
||
- A heap é uma lista de prioridade finita (pode ser implementada como array) | ||
- Cada dado da heap possui uma chave que determina sua prioridade | ||
- A heap é considerada uma árvore completa representada por vetor | ||
|
||
## Relembrando | ||
|
||
- Uma árvore completa possui as seguintes características: | ||
- Cada nó possui no máximo dois filhos | ||
- Os nós que não possuem filhos estão no último ou penúltimo nível | ||
- A heap é preenchida da esqueda para direita | ||
|
||
## Como organizar a Heap? | ||
|
||
- Utilizando os índices do vetor para organizar a heap | ||
- Chamamos o índices de `i` | ||
- Para encontrar os filhos de `i` fazemos: | ||
- Filho esquerdo - Fe = `2*i` se `2*i <= n` | ||
- Filho direito - Fd = `2*i+1` se `2*i <= n` | ||
- Para encontrar pai de `i` fazemos: | ||
- Pai de `i` - `Pi = i/2` (usa o valor base) se `i > 1` | ||
|
||
## Outra características | ||
|
||
- Nível dos elemento - `log(i)` | ||
- Altura do elemento - `log(n/i)` | ||
- As Subarvores - pode ser consecutiva ao vetor ou não | ||
|
||
## Verifique se os vetores são Heaps | ||
|
||
- Em uma heap, todo nó deve ter prioridade maior ou igual a prioridade de seus filhos, se eles existirem | ||
- Dados os vetores onde cada elemento chave é o valor de sua prioridade | ||
|
||
``` | ||
A1 = {15, 7, 9, 6, 5, 1, 4, 2} | ||
A2 = {15, 7, 9, 8, 5, 10, 4, 2} | ||
``` | ||
|
||
## Tipo de heap | ||
|
||
- Vimos exemplos onde o pai é sempre maior que os filhos | ||
- Chamamos esse tipo de heap de *heap máximo* | ||
- Quando a prioridade do pai é ser sempre menor que os filhos chamamos *heap mínimo* | ||
|
||
## Implementação - vamos discutir o heap máximo | ||
|
||
- Para facilitar a implementação vamos utilizar o vetor a partir do índice 1 | ||
- Logo nosso vetor deve ter o tamanho `n+1` | ||
- As operações | ||
- Inserir | ||
- Remover | ||
- Consultar o elemento de maior prioridade | ||
|
||
### Inserir | ||
|
||
data:image/s3,"s3://crabby-images/cbd17/cbd171e74d155fed696e7ff0aee4d6e3bd35e491" alt="Exemplo de Inserir" | ||
|
||
### Remover | ||
|
||
data:image/s3,"s3://crabby-images/0c625/0c6255f9ad3833075aaafd4f02bd0acd27900349" alt="Exemplo de Remover" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.