Algoritmos e Estruturas de Dados

Tamanho: px
Começar a partir da página:

Download "Algoritmos e Estruturas de Dados"

Transcrição

1 Introdução aos Algoritmos e Estruturas de Dados 2 o Teste - A LEIC Alameda, 2007/2008 Data: 12 de Junho de o Semestre Duração: 2h RESOLUÇÃO I. ( = 5.0 val.) I.a) Suponha que está a trabalhar com uma estrutura de dados que é uma árvore binária, em que a estrutura de cada nó foi declarada da seguinte forma: typedef struct node { int value; struct node *left; struct node *right; Node_t; Nesta estrutura de dados, todos os nós internos têm dois filhos, e as folhas têm ambos os ponteiros (left e right) com o valor NULL. Escreva uma função que aceite como argumento um ponteiro para um nó desta árvore e determine o número de folhas na árvore enraizada nesse nó que estão à profundidade máxima da árvore. Relembre que a profundidade da árvore é a distância entre a folha mais profunda e a raiz da árvore. Solução: A definir. 1/12

2 I.b) Escreva uma função que aceite como argumentos duas tabelas de inteiros, e respectivas dimensões. As tabelas estão ordenadas por ordem crescente. A função deverá retornar numa terceira tabela (que é o quinto argumento da função, e cuja dimensão é suficiente) uma lista ordenada dos valores presentes nas duas primeiras tabelas. A função deve retornar o valor da dimensão da tabela resultado. Por exemplo, se a função for chamada com os argumentos: ({1, 3, 7, 8, {2, 4, 9, 4, 3,...) deverá escrever na tabela resultado {1,2,3,4,7,8,9 e retornar o valor 7. O protótipo da função pretendida é: int merge(int tab1[], int tab2[], int n1, int n2, int tabres[]); Solução: A definir. 2/12

3 Grupo II ( = 6.0 val.) II.a) Indique qual dos seguintes vectores corresponde a um amontoado (heap). a. < 10,5,2,7,4,2,1,2,1 > b. < 10,9,8,7,6,9,8,7,6 > c. < 10,7,9,8,6,5,4,8,9 > d. < 8,10,9,7,6,5,4,8,9 > e. < 50,20,13,12,11,9,8,14,15 > f. < 50,20,10,16,18,9,8,15,14 > g. < 50,20,11,9,8,12, 10,7, 6 > Solução: A resposta certa é a f. 3/12

4 II.b) Considere a seguinte implementação do algoritmo heapsort em C: void heapsort(item a[], int l, int r) { 01 int k, N = r-l+1; 02 Item* pq = a+l-1; 03 for (k = N/2; k >= 1; k--) 04 fixdown(pq, k, N); 05 while (N > 1) { 06 exch(pq[1], pq[n]); 07 fixdown(pq, 1, --N); 08 A primeira operação do algoritmo heapsort é transformar o vector num amontoado. Considere a execução da função acima para a totalidade do seguinte vector: < 20,11,16,9,12,14,17,19, 13,15 > Indique qual o conteúdo do vector, imediatamente antes da execução da linha 05. a. < 20,17,19,15,13,16, 14,11,12, 9 > b. < 20,19,17,13,15,9,16,14, 12,11 > c. < 20,17,16,19,15,14, 13,12,11, 9 > d. < 20,19,17,15,13,16, 14,9, 11,12 > e. < 20,17,19,16,15,14, 13,12,11, 9 > f. < 20,19,17,13,15,14, 16,9, 11,12 > g. < 20,17,19,14,15,13, 9,16, 12,11 > Solução: A resposta certa é a f. 4/12

5 II.c) Considere a aplicação do algoritmo bubblesort ao seguinte vector: < 20,11,16,9,12,14,17,19, 13,15 > Supondo que o algoritmo percorre o vector da esquerda para a direita em cada iteração, qual o conteúdo do vector após as duas primeiras iterações do algoritmo bubblesort? a. < 9,12,11,13,14,16,15,17, 19,20 > b. < 11,16,9,12,14,17,19,13, 15,20 > c. < 11,9,12,14,16,17,13,15, 19,20 > d. < 9,11,12,14,16,13,15,17, 19,20 > e. < 9,11,12,13,14,16,15,17, 19,20 > f. < 11,9,12,16,13,14,15,17, 19,20 > g. < 9,11,12,15,13,17,14,16, 19,20 > Solução: A resposta certa é a c. 5/12

6 II.d) Considere a seguinte implementação em C do procedimento partition do algoritmo quicksort: void partition(int* A, int p, int r) { int x = A[r], i, j, a; for (i = p-1, j = p; j < r; j++) { if (A[j] <= x) { i++; a = A[i]; A[i] = A[j]; A[j] = a; a = A[r]; A[r] = A[i+1]; A[i+1] = a; Qual o conteúdo do vector A após invocar a função com os argumentos abaixo? A =< 20,11,16,9,12,14,17,19, 13,15 >, p = 0, r = 9 a. < 11,9,12,14,13,15,17,19, 16,20 > b. < 11,9,13,12,14,15,17,19, 16,20 > c. < 9,11,12,14,13,15,17,16, 20,19 > d. < 9,11,12,13,14,15,17,19, 16,20 > e. < 11,9,12,14,13,15,19,17, 20,16 > f. < 9,11,12,14,13,15,19,16, 20,17 > g. < 11,9,14,12,13,15,19,17, 20,16 > Solução: A resposta certa é a a. 6/12

7 Grupo III ( = 4.5 val.) III.a) Relativamente a árvores red-black, qual das seguintes afirmações é falsa? a. Um nó ou tem côr vermelha ou côr preta. b. Todos os caminhos de um nó até qualquer folha contêm sempre o mesmo número de nós de côr preta. c. O caminho mais longo, desde a raíz até qualquer folha, tem no pior caso comprimento igual ao dobro do comprimento do caminho mais curto, da raíz até qualquer folha. d. As folhas têm côr preta. e. Os filhos de nós de côr vermelha têm côr preta. f. A raiz tem côr preta. g. Os filhos de nós de côr preta têm côr vermelha. Solução: A resposta certa é a g. 7/12

8 III.b) Considere a implementação em C de uma árvore de pesquisa binária para inteiros, cujo o código é parcialmente reproduzido abaixo. #include <stdlib.h> struct BSTnode { int item; struct BSTnode* l; struct BSTnode* r; ; typedef struct BSTnode* link; static link head, z; link NEW(int item, link l, link r) { link x = malloc(sizeof(struct BSTnode)); x->item = item; x->l = l; x->r = r; return x; void BSTinit() { head = (z = NEW(0, NULL, NULL)); link insertr(link h, int item) { if (h == z) return NEW(item, z, z); if (item < h->item) h->l = insertr(h->l, item); else h->r = insertr(h->r, item); return h; void BSTinsert(int item) { head = insertr(head, item);... Assuma que, após invocar a função BSTinit(), invoca a função BSTinsert() para cada um dos elementos do seguinte vector, começando no primeiro e acabando no último: < 3,10,7,4,2,1,9,8, 5, 6 > Qual será a sequência de elementos visitados se, após a inserção dos elementos do vector acima, efectuarmos uma travessia em preorder da referida árvore? a. < 1,2,3,4,5,6,7,8, 9,10 > b. < 1,2,6,5,4,9,8,7, 10,3 > c. < 1,2,9,5,4,6,8,7, 10,3 > d. < 1,2,9,4,5,6,8,7, 10,3 > e. < 3,2,1,10,7,4,5,6,9,8 > f. < 3,2,6,10,8,4,5,1,9,7 > g. < 10,9,8,7,6,5,4,3,2,1 > Solução: A resposta certa é a e. 8/12

9 III.c) Considere uma tabela de dispersão com resolução por procura linear (linear probing), que permite guardar números inteiros. A tabela tem dimensão M = 10, e a respectiva função de dispersão é: hash(k) = k mod M Indique, para a inserção na tabela da sequência de números inteiros abaixo, qual será o índice da entrada da tabela em que é inserido o último elemento? < 10,18,5,25,46,101,39,17 > Nota: O operador mod representa o resto da divisão inteira (módulo). a. 1 b. 2 c. 3 d. 5 e. 7 f. 8 g. 9 Solução: A resposta certa é a b. 9/12

10 Grupo IV ( = 4.5 val.) IV.a) Considere a seguinte implementação em C do algoritmo counting sort, em que as linhas foram reordenadas aleatoriamente: void distcount(int a[], int l, int r) { 01 b[cnt[a[i]]++] = a[i]; 02 int i, j, cnt[m+1]; 03 cnt[a[i]+1]++; 04 for (i = l; i <= r; i++) 05 for (i = l; i <= r; i++) 06 for (j = 1; j < M; j++) 07 for (j = 0; j <= M; j++) 08 int b[maxn]; 09 for (i = l; i <= r; i++) 10 a[i] = b[i]; 11 cnt[j] = 0; 12 cnt[j] += cnt[j-1]; Qual a ordenação correcta para as linhas desta função? a. 08, 02, 04, 03, 07, 11, 05, 01, 06, 12, 09, 10 b. 08, 02, 04, 03, 07, 11, 09, 01, 05, 12, 06, 10 c. 08, 02, 07, 10, 09, 03, 06, 12, 05, 01, 04, 11 d. 02, 08, 04, 03, 07, 11, 09, 01, 05, 12, 06, 10 e. 02, 08, 07, 11, 04, 03, 06, 12, 05, 01, 09, 10 f. 02, 08, 05, 01, 09, 10, 07, 11, 04, 03, 06, 12 g. 01, 02, 03, 04, 05, 06, 07, 08, 09, 10, 11, 12 Solução: A resposta certa é a e. 10/12

11 IV.b) Considere o seguinte vector de números inteiros sem sinal de 6 bits: < 32,1,34,9,6,2,20,18,10 > Qual o conteúdo do vector após o primeiro passo do algoritmo de ordenação radix sort MSD, em que em cada passo os elementos são ordenados considerando 2 bits (ou seja, byte = 2 bits)? Nota: considere que o algoritmo é baseado numa versão estável do algoritmo counting sort. O algoritmo deve apenas processar os 6 bits menos significativos de cada número, independentemente dos números poderem ser guardados em palavras com maior número de bits. a. < 32,1,34,9,6,2,20,18,10 > b. < 1,9,6,2,10,20,18,32,34 > c. < 1,2,6,9,10,18,20,32,34 > d. < 10,18,20,2,6,9,34, 1,32 > e. < 1,9,2,6,10,18,20,32,34 > f. < 1,2,6,9,10,32,34,20,18 > g. < 1,10,18,2,20,32, 34,6, 9 > Solução: A resposta certa é a b. 11/12

12 IV.c) Considere a aplicação do algoritmo radix sort LSD ao seguinte vector de cadeias de caracteres: < aba,bca,abc,aab,baa,bcb,aaa,abb,cac > Assumindo que em cada passo de execução do algoritmo é analizado um caracter, qual será o conteúdo do vector após a execução do segundo passo? a. < aba,bca,baa,aaa,aab,bcb,abb,abc,cac > b. < aaa,aab,aba,abb,abc,baa,bca,bcb,cac > c. < aba,abc,aab,aaa,abb,bca,baa,bcb,cac > d. < aab,aaa,aba,abc,abb,baa,bca,bcb,cac > e. < baa,aaa,aab,cac,aba,abb,abc,bca,bcb > f. < baa,aaa,aba,bca,aab,abb,bcb,cac,abc > g. < aaa,baa,aba,bca,aab,abb,bcb,cac,abc > Solução: A resposta certa é a e. 12/12

Algoritmos e Estruturas de Dados

Algoritmos e Estruturas de Dados Introdução aos Algoritmos e Estruturas de Dados Repescagem 2 o Teste - B Ano lectivo: 2010/2011 2 o Semestre RESOLUÇÃO DA REPESCAGEM DO 2 o TESTE I. (2.5 + 2.5 + 3.0 = 8.0 val.) I.a) Considere o tipo Voo

Leia mais

INSTITUTO SUPERIOR TÉCNICO Introdução aos Algoritmos e Estruturas de Dados

INSTITUTO SUPERIOR TÉCNICO Introdução aos Algoritmos e Estruturas de Dados INSTITUTO SUPERIOR TÉCNICO Introdução aos Algoritmos e Estruturas de Dados Ano Lectivo de 2006/2007 2 o Semestre 2 o Teste A - 2 de Julho de 2007 Duração: 2h - O teste é sem consulta. - Para cada questão

Leia mais

Algoritmos e Estruturas de Dados

Algoritmos e Estruturas de Dados Introdução aos Algoritmos e Estruturas de Dados 2 o Teste - A Ano lectivo: 2010/2011 2 o Semestre RESOLUÇÃO DO 2 o TESTE Grupo I (2.0 + 2.5 + 2.0 = 6.5 val.) I.a) Considere os tipos enum ocasiao e Presente

Leia mais

INSTITUTO SUPERIOR TÉCNICO Algoritmos e Estruturas de Dados

INSTITUTO SUPERIOR TÉCNICO Algoritmos e Estruturas de Dados INSTITUTO SUPERIOR TÉCNICO Algoritmos e Estruturas de Dados Ano Lectivo de 2004/2005 2 o Semestre RESOLUÇÃO DO 2 o TESTE A I. (2.0+1.5+1.5 = 5.0 val.) a) Qual das seguintes declarações pode ser usada para

Leia mais

Algoritmos Eficientes de Ordenação

Algoritmos Eficientes de Ordenação AED 2002/2003 p.1/22 Algoritmos Eficientes de Ordenação Quick Sort Merge Sort Heap Sort Utilizar informação das chaves: Counting Sort Radix Sort AED 2002/2003 p.2/22 Quick Sort int partition(item a[],

Leia mais

Estruturas de dados elementares

Estruturas de dados elementares AED 2002/2003 p.1/31 Estruturas de dados elementares Tipos básicos Estruturas Tabelas Listas Amontoados AED 2002/2003 p.2/31 Tipos básicos Inteiros Reais Caracteres Ponteiros short a1; int a2; long a3;

Leia mais

Filas de prioridade e heapsort

Filas de prioridade e heapsort 1 Filas de prioridade e heapsort Além do Sedgewick (sempre leiam o Sedgewick), veja http://www.ime.usp.br/~pf/algoritmos/aulas/hpsrt.html 2 Filas de prioridade e heapsort Fila de prioridade: fila na qual

Leia mais

AED 2002/2003 p.1/16. Tabelas de Dispersão. Funçoes de dispersão Encadeamento externo Procura linear Double hashing Eficiência da procura

AED 2002/2003 p.1/16. Tabelas de Dispersão. Funçoes de dispersão Encadeamento externo Procura linear Double hashing Eficiência da procura AED 2002/2003 p.1/16 Tabelas de Dispersão Funçoes de dispersão Encadeamento externo Procura linear Double hashing Eficiência da procura AED 2002/2003 p.2/16 Funções de dispersão Deve distribuir as chaves

Leia mais

Estruturas de Dados. Módulo 17 - Busca. 2/6/2005 (c) Dept. Informática - PUC-Rio 1

Estruturas de Dados. Módulo 17 - Busca. 2/6/2005 (c) Dept. Informática - PUC-Rio 1 Estruturas de Dados Módulo 17 - Busca 2/6/2005 (c) Dept. Informática - PUC-Rio 1 Referências Waldemar Celes, Renato Cerqueira, José Lucas Rangel, Introdução a Estruturas de Dados, Editora Campus (2004)

Leia mais

Fontes Bibliográficas. Estruturas de Dados Aula 15: Árvores. Livros:

Fontes Bibliográficas. Estruturas de Dados Aula 15: Árvores. Livros: Fontes Bibliográficas Estruturas de Dados Aula 15: Árvores Livros: Introdução a Estruturas de Dados (Celes, Cerqueira e Rangel): Capítulo 13; Projeto de Algoritmos (Nivio Ziviani): Capítulo 5; Estruturas

Leia mais

Árvores Binárias Balanceadas Estrutura de Dados I

Árvores Binárias Balanceadas Estrutura de Dados I - entro de iências Exatas, Naturais e de Saúde Departamento de omputação Árvores inárias alanceadas Estrutura de Dados I OM06992 - Estrutura de Dados I Prof. Marcelo Otone guiar [email protected]

Leia mais

Listas ligadas/listas encadeadas

Listas ligadas/listas encadeadas 1 Listas ligadas/listas encadeadas Leitura recomendada: http://www.ime.usp.br/~pf/algoritmos/aulas/lista.html 2 Processamento elementar de listas Definição mais restritiva (tipo de lista possivelmente

Leia mais

Carlos Eduardo Batista. Centro de Informática - UFPB

Carlos Eduardo Batista. Centro de Informática - UFPB Estrutura de Dados Carlos Eduardo Batista Centro de Informática - UFPB [email protected] Aritmética de ponteiros em C (continuação) O que acontece na memória? Ponteiro para ponteiro etc. Métodos de pesquisa

Leia mais

Ordenação. Prof. Túlio A. M. Toffolo Prof. Marco Antonio M. Carvalho BCC402 Aula 04 Algoritmos e Programação Avançada

Ordenação. Prof. Túlio A. M. Toffolo Prof. Marco Antonio M. Carvalho   BCC402 Aula 04 Algoritmos e Programação Avançada Ordenação Prof. Túlio A. M. Toffolo Prof. Marco Antonio M. Carvalho http://www.toffolo.com.br BCC402 Aula 04 Algoritmos e Programação Avançada Aplicações Como testar se todos os elementos de um conjunto

Leia mais

DAINF - Departamento de Informática

DAINF - Departamento de Informática DAINF - Departamento de Informática Algoritmos 2 - Árvore binária de busca Prof. Alex Kutzke ( http://alex.kutzke.com.br/courses ) 30 de Novembro de 2015 Slides adaptados do material produzido pelo Prof.

Leia mais

ALGORITMOS E ESTRUTURAS DE DADOS CES-11 Prof. Paulo André Castro Sala 110 Prédio da Computação IECE - ITA

ALGORITMOS E ESTRUTURAS DE DADOS CES-11 Prof. Paulo André Castro Sala 110 Prédio da Computação   IECE - ITA ALGORITMOS E ESTRUTURAS DE DADOS CES-11 Prof. Paulo André Castro [email protected] Sala 110 Prédio da Computação www.comp.ita.br/~pauloac IECE - ITA MÉTODOS MAIS EFICIENTES QUE O(N 2 ) Método Quicksort Método

Leia mais

INF 1010 Estruturas de Dados Avançadas. Árvores binárias

INF 1010 Estruturas de Dados Avançadas. Árvores binárias INF 1010 Estruturas de Dados Avançadas Árvores binárias 1 Árvore estrutura hierárquica: A B E F C D G A B C E F D G A B C D E F G (A (B (E, F)), C, (D (G))) 05/09/16 2 Árvore - definições árvore: nó raiz

Leia mais

Aula T13 BCC202 Árvores. Túlio Toffolo

Aula T13 BCC202 Árvores. Túlio Toffolo Aula T13 BCC202 Árvores Túlio Toffolo www.decom.ufop.br/toffolo Conceitos básicos n Organiza um conjunto de acordo com uma estrutura hierárquica. n Contém elementos que são chamados de nós n O pai de todos

Leia mais

Aula 13: Ordenação - Heapsort. Bruno Hott Algoritmos e Estruturas de Dados I DECSI UFOP

Aula 13: Ordenação - Heapsort. Bruno Hott Algoritmos e Estruturas de Dados I DECSI UFOP Aula 13: Ordenação - Heapsort Bruno Hott Algoritmos e Estruturas de Dados I DECSI UFOP Filas de Prioridades É uma estrutura de dados onde a chave de cada item reflete sua habilidade relativa de abandonar

Leia mais

Árvore Binária de Busca. Prof. César Melo

Árvore Binária de Busca. Prof. César Melo Árvore Binária de Busca Prof. César Melo Introdução O algoritmo de busca binária em vetores tem bom desempenho e deve ser usado quando temos os dados já ordenados. No entanto, se precisarmos inserir e

Leia mais

Ordenação: Heapsort. Algoritmos e Estruturas de Dados II

Ordenação: Heapsort. Algoritmos e Estruturas de Dados II Ordenação: Heapsort Algoritmos e Estruturas de Dados II Introdução Possui o mesmo princípio de funcionamento da ordenação por seleção Selecione o menor item do vetor Troque-o pelo item da primeira posição

Leia mais

Heaps. Estrutura de Dados. Universidade Federal de Juiz de Fora Departamento de Ciência da Computação 1 / 35

Heaps. Estrutura de Dados. Universidade Federal de Juiz de Fora Departamento de Ciência da Computação 1 / 35 Heaps Estrutura de Dados Universidade Federal de Juiz de Fora Departamento de Ciência da Computação 1 / 35 Conteúdo Introdução Definição de Heap Heap Binária Implementação com vetor Fila de Prioridades

Leia mais

Algoritmos e Estruturas de dados

Algoritmos e Estruturas de dados Algoritmos e Estruturas de dados Listas Encadeadas Prof. Dr. Fábio Rodrigues de la Rocha (Listas Encadeadas) 1 / 21 Definição: Anteriormente estudamos listas encadeadas que foram implementadas como vetores

Leia mais

Árvores Binária de Busca. Prof. César Melo DCC/ICE/UFAM

Árvores Binária de Busca. Prof. César Melo DCC/ICE/UFAM Árvores Binária de Busca Prof. César Melo DCC/ICE/UFAM Introdução O algoritmo de busca binária em vetores tem bom desempenho e deve ser usado quando temos os dados já ordenados. No entanto, se precisarmos

Leia mais

INF111 Programação II Aulas 11, 12, 13 Ordenação

INF111 Programação II Aulas 11, 12, 13 Ordenação INF Programação II Aulas,, Ordenação Departamento de Informática UFV Ordenação A ordenação é o processo de organizar um conunto (vetor) de n obetos ou registros segundo uma determinada ordem crescente

Leia mais

Árvores Binárias de Busca (ABB) 18/11

Árvores Binárias de Busca (ABB) 18/11 Árvores Binárias de Busca (ABB) 18/11 Definição Uma Árvore Binária de Busca possui as mesmas propriedades de uma AB, acrescida da seguintes propriedade: Para todo nó da árvore, se seu valor é X, então:

Leia mais

Edital de Seleção 032/2016 PROPESP/UFAM. Prova de Conhecimento. Caderno de Questões

Edital de Seleção 032/2016 PROPESP/UFAM. Prova de Conhecimento. Caderno de Questões Edital de Seleção 032/2016 PROPESP/UFAM Prova de Conhecimento Caderno de Questões CANDIDATO: INSCRIÇÃO: Assinatura conforme identidade INSTRUÇÕES PARA O CANDIDATO: Verifique o seu nome e o número da sua

Leia mais

Algoritmos de Ordenação: Tempo Linear

Algoritmos de Ordenação: Tempo Linear Algoritmos de Ordenação: Tempo Linear ACH2002 - Introdução à Ciência da Computação II Delano M. Beder Escola de Artes, Ciências e Humanidades (EACH) Universidade de São Paulo [email protected] 10/2008 Material

Leia mais

UNIVERSIDADE DA BEIRA INTERIOR

UNIVERSIDADE DA BEIRA INTERIOR UNIVERSIDADE DA BEIRA INTERIOR Algoritmos e Estruturas de Dados - Bioengenharia 2º Semestre Exame Especial Resolução 19/07/2013 A. [4.75 val] Algoritmos de ordenação e de pesquisa (usando memória estática

Leia mais

Árvores Binárias de Busca

Árvores Binárias de Busca Árvores Binárias de Busca SCC0202 - Algoritmos e Estruturas de Dados I Prof. Fernando V. Paulovich *Baseado no material do Prof. Gustavo Batista http://www.icmc.usp.br/~paulovic [email protected] Instituto

Leia mais

Análise de algoritmos

Análise de algoritmos Análise de algoritmos Ordenação em tempo linear Prof. Flávio Rogério Uber (UEM/DIN) Autor: Prof. Marco Aurélio Lopes Barbosa (UEM/DIN) Conteúdo Limites inferiores para ordenação por comparações Ordenação

Leia mais

Departamento de Informática - PUC-Rio INF 1007 Programação 2 P4 07/12/2010

Departamento de Informática - PUC-Rio INF 1007 Programação 2 P4 07/12/2010 Departamento de Informática - PUC-Rio INF 1007 Programação 2 P4 07/12/2010 Aluno: Matrícula: Turma: Instruções: 1) Escreva seu nome completo, matrícula e turma; 2) A prova deve ser completamente resolvida

Leia mais

1. O que é a eficiência assintótica de um algoritmo. Explique com suas palavras.

1. O que é a eficiência assintótica de um algoritmo. Explique com suas palavras. Disciplina: Estrutura de Dados II Turma: 4EC/5CC Data: 13/11/15 Nota: Professor: Renato E. N. de Moraes Semestre: 2015-2 Valor: 0,0 pts Aluno: Lista de exercícios 04 1. O que é a eficiência assintótica

Leia mais

max1: 20,max2:+ max1:15, max2:20 max1:30,max2:32,max3:35 max1:40,max2:+

max1: 20,max2:+ max1:15, max2:20 max1:30,max2:32,max3:35 max1:40,max2:+ Estruturas de Dados Algumas Respostas da Lista 4 Angelo Ciarlini 1- Mostre o aspecto de uma árvore 2-3 que armazena números inteiros após a inserção dos números 30, 20, 10, 40, 15, 35 e 32, nesta ordem.

Leia mais

INF 1620 P4-27/06/02 Questão 1 Nome:

INF 1620 P4-27/06/02 Questão 1 Nome: INF 1620 P4-27/06/02 Questão 1 Considere o tipo que representa uma grandeza vetorial (com três componentes) dado por: struct vetor { float x; float y; float z; }; typedef vetor Vetor; Pede-se: (a) Escreva

Leia mais

Tipos abstratos de dados; pilhas e filas

Tipos abstratos de dados; pilhas e filas 1 Tipos abstratos de dados; pilhas e filas Além do Sedgewick (sempre leiam o Sedgewick), veja http://www.ime.usp.br/~pf/algoritmos/aulas/pilha.html http://www.ime.usp.br/~pf/algoritmos/aulas/fila.html

Leia mais

INF1007: Programação 2 6 Ordenação de Vetores. 01/10/2015 (c) Dept. Informática - PUC-Rio 1

INF1007: Programação 2 6 Ordenação de Vetores. 01/10/2015 (c) Dept. Informática - PUC-Rio 1 INF1007: Programação 2 6 Ordenação de Vetores 01/10/2015 (c) Dept. Informática - PUC-Rio 1 Tópicos Introdução Ordenação bolha (bubble sort) Ordenação por seleção (selection sort) 01/10/2015 (c) Dept. Informática

Leia mais

Árvores Binárias. SCC Algoritmos e Estruturas de Dados I. Prof. Fernando V. Paulovich

Árvores Binárias. SCC Algoritmos e Estruturas de Dados I. Prof. Fernando V. Paulovich Árvores Binárias SCC0202 - Algoritmos e Estruturas de Dados I Prof. Fernando V. Paulovich *Baseado no material do Prof. Gustavo Batista. Figuras editadas por Isadora Maria Mendes http://www.icmc.usp.br/~paulovic

Leia mais

ESTRUTURAS DE DADOS E ALGORITMOS ALGORITMOS DE ORDENAÇÃO POR COMPARAÇÃO - II

ESTRUTURAS DE DADOS E ALGORITMOS ALGORITMOS DE ORDENAÇÃO POR COMPARAÇÃO - II ESTRUTURAS DE DADOS E ALGORITMOS ALGORITMOS DE ORDENAÇÃO POR COMPARAÇÃO - II Adalberto Cajueiro Departamento de Sistemas e Computação Universidade Federal de Campina Grande ALGORITMOS VISTOS ANTERIORMENTE

Leia mais

Edital de Seleção 053/2016 PROPESP/UFAM. Prova de Conhecimento. Caderno de Questões

Edital de Seleção 053/2016 PROPESP/UFAM. Prova de Conhecimento. Caderno de Questões Edital de Seleção 053/2016 PROPESP/UFAM Prova de Conhecimento Caderno de Questões CANDIDATO: INSCRIÇÃO: Assinatura conforme identidade INSTRUÇÕES PARA O CANDIDATO: Verifique o seu nome e o número da sua

Leia mais

Edital de Seleção 024/2017 PROPESP/UFAM. Prova de Conhecimento. Caderno de Questões

Edital de Seleção 024/2017 PROPESP/UFAM. Prova de Conhecimento. Caderno de Questões Edital de Seleção 024/2017 PROPESP/UFAM Prova de Conhecimento Caderno de Questões CANDIDATO: «Nome» INSCRIÇÃO: «Inscrição» Assinatura conforme identidade INSTRUÇÕES PARA O CANDIDATO: Verifique o seu nome

Leia mais

Árvores Binárias de Busca

Árvores Binárias de Busca 0. Um breve comentário sobre os algoritmos de busca em tabelas De uma maneira geral, realizam-se operações de busca, inserção e remoção de elementos numa tabela. A busca sequencial tradicional é O(N).

Leia mais

Tabelas de Dispersão. Algoritmos e Estruturas de Dados Verão Cátia Vaz 1

Tabelas de Dispersão. Algoritmos e Estruturas de Dados Verão Cátia Vaz 1 Tabelas de Dispersão Algoritmos e Estruturas de Dados Verão 2012 1 Tabelas de endereçamento directo Endereçamento directo é usado quando o universo de chaves é pequeno e todas as chaves são distintas:

Leia mais

HeapSort. Estrutura de Dados II Jairo Francisco de Souza

HeapSort. Estrutura de Dados II Jairo Francisco de Souza HeapSort Estrutura de Dados II Jairo Francisco de Souza HeapSort Algoritmo criado por John Williams (1964) Complexidade O(NlogN) no pior e médio caso Mesmo tendo a mesma complexidade no caso médio que

Leia mais

HeapSort Filas de Prioridade Heap. David Menotti Algoritmos e Estruturas de Dados II DInf UFPR

HeapSort Filas de Prioridade Heap. David Menotti Algoritmos e Estruturas de Dados II DInf UFPR HeapSort Filas de Prioridade Heap David Menotti Algoritmos e Estruturas de Dados II DInf UFPR Filas de Prioridades É uma estrutura de dados onde a chave de cada item reflete sua habilidade relativa de

Leia mais

MAC121 ALGORITMOS E ESTRUTURAS DE DADOS I 2O. SEMESTRE DE 2017

MAC121 ALGORITMOS E ESTRUTURAS DE DADOS I 2O. SEMESTRE DE 2017 PROVA 1 MAC121 ALGORITMOS E ESTRUTURAS DE DADOS I 2O. SEMESTRE DE 2017 Nome: Número USP: Instruções: (1 ) Esta prova é individual. (2 ) Não destaque as folhas deste caderno. (3 ) A prova consiste de 6

Leia mais

Aula 08. Estruturas de dados Árvore e Grafo

Aula 08. Estruturas de dados Árvore e Grafo Logo Aula 08 Estruturas de dados Árvore e Grafo 2 Árvore Estruturas estudadas até agora não são \ adequadas para representar dados que devem ser dispostos de maneira hierárquica Ex., hierarquia de pastas

Leia mais

UNIVERSIDADE FEDERAL DO PIAUÍ COLÉGIO TÉCNICO DE TERESINA-TÉCNICO EM INFORMÁTICA DISCIPLINA: ESTRUTURA DE DADOS PROFESSOR: Valdemir Junior

UNIVERSIDADE FEDERAL DO PIAUÍ COLÉGIO TÉCNICO DE TERESINA-TÉCNICO EM INFORMÁTICA DISCIPLINA: ESTRUTURA DE DADOS PROFESSOR: Valdemir Junior UNIVERSIDADE FEDERAL DO PIAUÍ COLÉGIO TÉCNICO DE TERESINA-TÉCNICO EM INFORMÁTICA DISCIPLINA: ESTRUTURA DE DADOS PROFESSOR: Valdemir Junior ALGORITMO DE ORDENAÇÃO HEAPSORT Alyson Pereira Barbosa Erisvaldo

Leia mais

Marcelo Keese Albertini Faculdade de Computação Universidade Federal de Uberlândia

Marcelo Keese Albertini Faculdade de Computação Universidade Federal de Uberlândia Introdução à Análise de Algoritmos Marcelo Keese Albertini Faculdade de Computação Universidade Federal de Uberlândia Aula de hoje Nesta aula veremos: Sobre a disciplina Exemplo: ordenação Sobre a disciplina

Leia mais

Lista Ordenada. Estrutura de Dados. Universidade Federal de Juiz de Fora Departamento de Ciência da Computação 1 / 35

Lista Ordenada. Estrutura de Dados. Universidade Federal de Juiz de Fora Departamento de Ciência da Computação 1 / 35 Lista Ordenada Estrutura de Dados Universidade Federal de Juiz de Fora Departamento de Ciência da Computação 1 / 35 Conteúdo Definição Operações Representações Contígua Encadeada Aplicação Exercícios 2

Leia mais

Aplicação de Árvores: Código de Huffman

Aplicação de Árvores: Código de Huffman Aplicação de Árvores: Código de Huffman SCC0202 - Algoritmos e Estruturas de Dados I Prof. Fernando V. Paulovich http://www.icmc.usp.br/~paulovic [email protected] Instituto de Ciências Matemáticas

Leia mais

ÁRVORE BINÁRIA DE BUSCA

ÁRVORE BINÁRIA DE BUSCA ÁRVORE BINÁRIA DE BUSCA Introdução O algoritmo de busca binária em vetores tem bom desempenho e deve ser usado quando temos os dados já ordenados. No entanto, se precisarmos inserir e remover elementos

Leia mais