• Nenhum resultado encontrado

MAC 6711 - T´opicos de An´alise de Algoritmos Departamento de Ciˆencia da Computa¸c˜ao Primeiro semestre de 2010 Lista 5 1.

N/A
N/A
Protected

Academic year: 2022

Share "MAC 6711 - T´opicos de An´alise de Algoritmos Departamento de Ciˆencia da Computa¸c˜ao Primeiro semestre de 2010 Lista 5 1."

Copied!
1
0
0

Texto

(1)

MAC 6711 - T´opicos de An´alise de Algoritmos Departamento de Ciˆencia da Computa¸c˜ao

Primeiro semestre de 2010 Lista 5

1. (Exerc´ıcios 18.1-2 do CLR) Mostre que se uma opera¸c˜ao Decrementa for inclu´ıda nas opera¸c˜oes de manipula¸c˜ao de um contador bin´ario com kbits, n opera¸c˜oes poderiam custar tempo Θ(nk).

2. Uma seq¨uˆencia denopera¸c˜oes ´e executada em uma estrutura de dados. Ai-´esima opera¸c˜ao custa i sei ´e uma potˆencia de 2, e 1 caso contr´ario. Determine o tempo amortizado por opera¸c˜ao.

3. Uma seq¨uˆencia de opera¸c˜oes sobre uma pilha ´e executada numa pilha cujo tamanho nunca excedek. Depois de cada k opera¸c˜oes, uma c´opia da pilha toda ´e feita para prop´osito de back-up. Mostre que o custo de n opera¸c˜oes sobre a pilha, incluindo a opera¸c˜ao de c´opia paraback-up, ´eO(n), atribuindo valores adequados de cr´editos a cada opera¸c˜ao.

4. Suponha que desejamos n˜ao apenas incrementar um contador mas tamb´em algumas vezes reinicializ´a-lo com zero. Mostre como implementar um contador com um vetor bin´ario de maneira que qualquer seq¨uˆencia de n opera¸c˜oes incrementa1e zera contadorconsuma tempo O(n), desde que o contador esteja inicialmente com zero. (Dica: Mantenha um apontador para o 1 mais significativo do contador.)

5. Considere a implementa¸c˜ao de lista ligada para representar conjuntos disjuntos. Sugira uma mudan¸ca simples da rotinaunionque n˜ao necessite do apontadorfimpara o ´ultimo da lista de cada conjunto. Sua sugest˜ao deve ser tal que, independente de estarmos ou n˜ao usando a heur´ıstica dos tamanhos (anexe no final a lista menor), o consumo assint´otico de tempo de pior caso deve se manter igual.

6. Mostre que lg(lgn) =O(lg(lgn)).

7. Considere a implementa¸c˜ao do union-find por ´arvores enraizadas. Escreva uma vers˜ao n˜ao recursiva dofindset com compress˜ao de caminhos.

8. Considere a implementa¸c˜ao do union-find por ´arvores enraizadas com compress˜ao de ca- minhos e heur´ıstica dos ranks (a ´arvore de menor rank ´e pendurada na de menor rank no union). Considere uma seq¨uˆencia qualquer (v´alida) de m opera¸c˜oesmakeset,findset e linkem que todas as opera¸c˜oeslinkaparecem antes das opera¸c˜oesfindset. Mostre que tal seq¨uˆencia consome, no pior caso, tempoO(m). O que acontece com o tempo consumido por uma seq¨uˆencia deste tipo se apenas compress˜ao de caminhos estiver implementada?

Referências

Documentos relacionados

Escreva um algoritmo que ordena uma lista de n itens dividindo-a em trˆes sublistas de aproxi- madamente n/3 itens, ordenando cada sublista recursivamente e intercalando as

Projete um algoritmo de divis˜ ao e conquista para resolver o problema e compare-o ao m´etodo derivado da regra de Horner.. Descreva um algoritmo que, dados inteiros n e k,

(O k-´ esimo m´ınimo de um vetor de inteiros distintos ´ e o elemento que estaria na k-´ esima posi¸c˜ ao do vetor se ele

Mostre que a probabilidade do algoritmo de Karger sugerido no exerc´ıcio 12 do KT dar uma resposta correta, ou seja, um s-t corte m´ınimo, ´e exponencialmente pequena no n´ umero n

Considere a seguinte implementa¸c˜ ao da estrutura de dados para armazenar uma cole¸c˜ ao de con- juntos disjuntos, conhecida como union-find :. makeset

Mostre um exemplo para os trˆes primeiros crit´erios gulosos apresentados para o problema da cole¸c˜ ao m´ axima de intervalos disjuntos visto em aula que prove que o algoritmo

A miss˜ ao da ´ area de algoritmos consiste em duas partes: a tarefa de identificar o ponto central do problema e coloc´ a-lo em um formato matematicamente limpo, e ent˜ ao a tarefa

Essas duas partes interagem: quanto mais confort´ avel se est´ a com a variedade de t´ecnicas dispon´ıveis de projeto de algoritmos, mais frequentemente se consegue reconhecer