PAA-DaniloEler-Divisão e Conquista
Transcript of PAA-DaniloEler-Divisão e Conquista
![Page 1: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/1.jpg)
Projeto e Análise de
Algoritmos:
Divisão e Conquista
Departamento de Matemática e Computação
Faculdade de Ciências e Tecnologia
Unesp – Universidade Estadual Paulista
Presidente Prudente/SP, Brasil
Prof. Danilo Medeiros Eler
FCT/Unesp – Presidente Prudente
Departamento de Matemática e Computação
(apresentação adaptada: ver referências no final)
![Page 2: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/2.jpg)
Divisão e Conquista
![Page 3: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/3.jpg)
Divisão e Conquista
![Page 4: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/4.jpg)
Divisão e Conquista
Não é aplicado unicamente a problemas
recursivos
Em geral as estratégias de resolução de
problemas envolvem um dos cenários
abaixo:
Processar separadamente partes do conjunto,
mas a solução de uma parte influencia no
resultado de outra
Eliminar partes dos dados a serem processados
![Page 5: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/5.jpg)
Exemplo 1: Merge-Sort
Processar separadamente partes do conjunto
A solução de uma influência na de outra
![Page 6: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/6.jpg)
Exemplo 2: somaProcessar separadamente partes do conjunto
![Page 7: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/7.jpg)
Exemplo 3: busca binária
Eliminar partes do conjunto de dados
![Page 8: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/8.jpg)
Convex Hull
Convex Hull (Fecho Convexo)
É um dos problemas mais interessantes da
geometria computacional
O objetivo é encontrar o fecho convexo que
englobe um conjunto de pontos no plano
cartesiano
![Page 9: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/9.jpg)
Convex Hull Se tivéssemos um conjunto de pregos e
soltássemos um elástico em volta, os pregos
envolvidos pelo elástico formam o fecho
convexo desse conjunto
![Page 10: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/10.jpg)
Convex Hull
Dado um conjunto de pontos
![Page 11: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/11.jpg)
Convex Hull
O fecho convexo é o menor polígono convexo que
contém todos os pontos do conjunto
![Page 12: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/12.jpg)
Convex Hull
Exemplo: minimizar o caminho de p a q, sem
pular o obstáculo
![Page 13: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/13.jpg)
Convex Hull
Exemplo: minimizar o caminho de p a q, sem
pular o obstáculo
![Page 14: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/14.jpg)
Convex Hull
Exemplo: minimizar o caminho de p a q, sem
pular o obstáculo
![Page 15: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/15.jpg)
Convex Hull
Uma maneira rápida de calcular o fecho
convexo é por meio da técnica de divisão e
conquista
Dividimos o conjunto de pontos ao meio até
chegar em um conjunto com 3 pontos ou
menos
Então criamos de maneira simples o fecho desse
subconjunto
Em seguida, a etapa de conquista, consiste
em unir os fechos previamente criados
![Page 16: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/16.jpg)
Convex Hull
convexHull(pontos, ini, fim)
se (fim - inicio + 1) > 3) {
int meio = (inicio + fim) / 2;
Poligono esq = convexHull(pontos, ini, meio);
Poligono dir = convexHull(pontos, meio + 1, fim);
retorna merge(esq, dir);
else
retorna criaPoligonoBase(pontos, ini, fim);
fimse
fim
![Page 17: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/17.jpg)
Convex Hull
![Page 18: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/18.jpg)
Convex Hull
![Page 19: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/19.jpg)
Convex Hull
![Page 20: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/20.jpg)
Convex Hull
![Page 21: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/21.jpg)
Convex Hull
![Page 22: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/22.jpg)
Convex Hull
![Page 23: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/23.jpg)
Convex Hull
![Page 24: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/24.jpg)
Convex Hull
![Page 25: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/25.jpg)
Convex Hull
![Page 26: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/26.jpg)
Convex Hull
Não é convexo
![Page 27: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/27.jpg)
Convex Hull
É convexo
![Page 28: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/28.jpg)
Convex Hull
Não é convexo
![Page 29: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/29.jpg)
Convex Hull
É convexo
![Page 30: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/30.jpg)
Convex Hull
É convexo
![Page 31: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/31.jpg)
Convex Hull
É possível identificar as orientações dos
pontos de uma tripla (A, B, C)
![Page 32: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/32.jpg)
Convex Hull
![Page 33: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/33.jpg)
Convex Hull
![Page 34: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/34.jpg)
Convex Hull
![Page 35: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/35.jpg)
Convex Hull
![Page 36: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/36.jpg)
Convex Hull
![Page 37: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/37.jpg)
Convex Hull
![Page 38: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/38.jpg)
Convex Hull Tangente superior
Sentido Anti-horário
Não é convexo
A
B
C
![Page 39: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/39.jpg)
Convex Hull Tangente superior
Sentido Horário
É convexo
A
B
C
![Page 40: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/40.jpg)
Convex Hull Tangente inferior
Sentido Horário
Não é convexo
A
B
C
![Page 41: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/41.jpg)
Convex Hull Tangente inferior
Sentido Anti-Horário
É convexo
A
B
C
![Page 42: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/42.jpg)
Convex Hull
![Page 43: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/43.jpg)
Convex Hull Não é convexo
![Page 44: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/44.jpg)
Convex Hull Não é convexo
![Page 45: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/45.jpg)
Convex Hull Não é convexo
![Page 46: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/46.jpg)
Convex Hull É convexo
![Page 47: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/47.jpg)
Convex Hull Não é convexo
![Page 48: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/48.jpg)
Convex Hull Não é convexo
![Page 49: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/49.jpg)
Convex Hull É convexo
![Page 50: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/50.jpg)
Convex Hull É convexo
![Page 51: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/51.jpg)
Convex Hull
![Page 52: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/52.jpg)
Parte inicial deste material foi adaptado de
Professor Moacir Ponti Junior
ICMC/USP – São Carlos
Aula:
Projeto de Algoritmos: paradigmas
SCC201/501 - Introdução à Ciência de Computação II
![Page 53: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/53.jpg)
Bibliografia
LEVITIN, A. Introduction to The Design & Analysis of
Algorithms, Addison Wesley, 2003, 497p.
CORMEN, T. H.; LEISERSON, C. E.; RIVEST, R. L.;
(2002). Algoritmos –Teoria e Prática. Tradução da 2ª
edição americana. Rio de Janeiro. Editora Campus
TAMASSIA, ROBERTO; GOODRICH, MICHAEL T.
(2004). Projeto de Algoritmos -Fundamentos, Análise e
Exemplos da Internet
ZIVIANI, N. (2007). Projeto e Algoritmos com
implementações em Java e C++. São Paulo. Editora
Thomson
![Page 54: PAA-DaniloEler-Divisão e Conquista](https://reader034.fdocuments.net/reader034/viewer/2022042617/626410077ebeaf2641285656/html5/thumbnails/54.jpg)
54
Bibliografia