Complexidade de Algoritmos
|
|
|
- Thereza Balsemão Castro
- 8 Há anos
- Visualizações:
Transcrição
1 Complexidade de Algoritmos
2 O que é um algoritmo? Sequência bem definida e finita de cálculos que, para um dado valor de entrada, retorna uma saída desejada/esperada. Na computação: Uma descrição de como resolver um problema proposto.
3 Exemplos de Algoritmos Algoritmo de Euclides: Definição: o maior divisor comum entre dois ou mais números é chamado de máximo divisor comum (mdc). Problema: dados dois números inteiros maiores que zero, encontrar o maior denominador comum entre eles. Entrada: dois números inteiros a, b > 0.
4 Exemplos de Algoritmos Algoritmo de Euclides 1 Entrada: a, b 2 Enquanto a b faça 3 Se a > b então 4 a = a b 5 Senão 6 b = b a 7 Saída: a
5 Exemplos de Algoritmos
6 Exemplos de Algoritmos Ordenação de Vetores por Inserção 1 Entrada: V 2 Para j=2 até n faça 3 valor_atual = j 4 i = j-1 5 Enquanto i 1 e V i > valor_atual faça 6 V i+1 = V i 7 i = i 1 8 V i+1 = valor_atual 9 Saída: V
7 Instância de um Problema Instância de um problema é um conjunto qualquer de valores que é uma entrada válida para esse: No algoritmo de Euclides temos que a=124 e b=245 é uma instância do problema. No algoritmo de ordenação uma instância do problema seria: V = [12, 32, 4, 25, 21, 44].
8 Análise de Algoritmo Ao analisar um algoritmo 3 aspectos são de grande importância: Finitude: o algoritmo é composto de passos finitos? Corretude: o algoritmo resolve o problema proposto? Complexidade: quantas instruções são necessárias para obter a solução de uma instância do problema?
9 Análise de Algoritmo Finitude: o algoritmo é composto de passos finitos? Corretude: o algoritmo resolve o problema proposto? Complexidade: quantas instruções são necessárias para obter a solução de uma instância do problema?
10 Finitude do Algoritmo O algoritmo de Euclides sempre tem fim? Uma vez que é garantido realizar a operação de subtração do maior número (a) pelo menor número (b), o resultado será um valor x, tal que a > x 0 e que substituirá o valor em a.
11 Finitude do Algoritmo O algoritmo de Euclides sempre tem fim? Dado também que a e b são inteiros, e o maio valor entre esses dois diminui a cada iteração, eventualmente, em sucessivas subtrações, um deles atingirá o valor de 0.
12 Finitude do Algoritmo O algoritmo de Euclides sempre tem fim? Porém, para resultar em 0 os valores de a e b na iteração anterior devem ser iguais, logo definindo o critério de parada como verdadeiro.
13 Finitude do Algoritmo O algoritmo de ordenação por inserção sempre tem fim? O laço principal desse algoritmo é bem definido, repetindo a iteração n-1 vezes.
14 Finitude do Algoritmo O algoritmo de ordenação por inserção sempre tem fim? O laço interno inicia sua operação com i = j-1 1 e decrementa seu valor a cada iteração, eventualmente chegando ao valor i=0, saindo do laço.
15 Análise de Algoritmo Finitude: o algoritmo é composto de passos finitos? Corretude: o algoritmo resolve o problema proposto? Complexidade: quantas instruções são necessárias para obter a solução de uma instância do problema?
16 Corretude de um Algoritmo Um algoritmo é dito correto se: Para qualquer instância do problema ele retorna a solução correta em tempo finito. Algoritmos incorretos também podem ser úteis.
17 Corretude de um Algoritmo O algoritmo de Euclides está correto? Dado que o mdc(a,b) = mdc(a-x,b) = mdc(a,b-y), com x < a e y < b então temos que: mdc(a,b) = mdc(a-b,b), com a > b Com essa propriedade do mdc garantimos que o resultado final não é alterado durante as sucessivas subtrações.
18 Corretude de um Algoritmo O algoritmo de Euclides está correto? Dado que o mdc(a,a) = a, garantimos que a solução final, quando os dois valores são iguais, está correto.
19 Corretude de um Algoritmo O algoritmo de ordenação por inserção está correto? Para provar que sim utilizaremos uma invariante de um laço e técnica de indução matemática.
20 Invariante de um Laço Invariante de um laço é um estado ou condição de uma variável que é invariante durante a execução das iterações. Com essa invariante é possível mostrar a corretude do algoritmo ao longo dos laços contidos nele.
21 Corretude de um Algoritmo O algoritmo de ordenação por inserção está correto? Para o laço principal do algoritmo podemos supor que a invariante é que o vetor V está ordenado para os índices de 1..j-1
22 Corretude de um Algoritmo O algoritmo de ordenação por inserção está correto? Utilizando indução matemática precisamos primeiro mostrar que na primeira iteração (j=2) o subvetor V(1..j-1) está ordenado. Como esse subvetor é composto por apenas um elemento, então ele está ordenado.
23 Corretude de um Algoritmo O algoritmo de ordenação por inserção está correto? Agora, dado que o subvetor está ordenado na iteração em que j=k, precisamos mostrar que ele estará ordenado na iteração j=k+1.
24 Corretude de um Algoritmo O algoritmo de ordenação por inserção está correto? Em suma, o laço interno guarda o elemento j=k+1 e empurra os outros elementos em uma posição adiante até encontrar a posição correta para esse elemento, tendo ao final um subvetor ordenado V(1..k+1).
25 Análise de Algoritmo Finitude: o algoritmo é composto de passos finitos? Corretude: o algoritmo resolve o problema proposto? Complexidade: quantas instruções são necessárias para obter a solução de uma instância do problema?
26 Complexidade de um Algoritmo Nos dias atuais, com o avanço crescente da capacidade de computação, o uso do algoritmo mais rápido ainda é importante? Suponha que temos dois computadores disponíveis: computador C1 capaz de realizar 10 9 operações por segundo e; computador C2 capaz de realizar 10 6 operações por segundo.
27 Complexidade de um Algoritmo Suponha também que temos dois algoritmos para realizar uma operação: algoritmo A1, que necessita executar n 2 operações e; algoritmo A2, que necessita executar n.log(n) operações.
28 Complexidade de um Algoritmo Executando A1 em C1 e A2 em C2 e sendo n=10 6, temos: A1 em C1: (10 6 ) 2 instruções / 10 9 instruções por seg segs. A2 em C2: 10 6.log(10 6 ) instruções / 10 6 instruções por seg. 6 segs. A2 foi cerca de 160x mais rápido que A1, mesmo em uma máquina 1000x mais lenta.
29 Complexidade de um Algoritmo Executando A1 em C1 e A2 em C2 e sendo n=10 6, temos: A1 em C1: (10 6 ) 2 instruções / 10 9 instruções por seg segs. A2 em C2: 10 6.log(10 6 ) instruções / 10 6 instruções por seg. 6 segs. Se o tamanho do problema aumentar em 10x, A1 levará mais ou menos 1 dia enquanto A2 levará 70 segundos!!!
30 Medida de Complexidade de Algoritmo A complexidade de tempo de um algoritmo, ou eficiência, é mensurada como o número de instruções básicas que ele executa em função do tamanho da entrada. Geralmente essa medida é efetuada levando em conta o pior caso do algoritmo: a instância daquele tamanho que leva o maior tempo.
31 Medida de Complexidade de Algoritmo De forma a determinar a complexidade do algoritmo nas situações que realmente interessam, é feita uma análise assintótica da complexidade. Análise assintótica: análise feita em instâncias MUITO GRANDES do problema.
32 Algoritmos Eficientes O algoritmo é dito eficiente se a complexidade dele é polinomial em função do tamanho da entrada: n, n 2, n 3, n 4, Eles são considerados eficientes pois são funções bem comportadas e não crescem tão rapidamente conforme o tamanho do problema.
33 Complexidade Para determinar a complexidade do algoritmo é necessário verificar a contagem de tempo das operações elementares do algoritmo em função do tamanho da entrada. O tamanho da entrada para o algoritmo de ordenação pode ser considerado o tamanho do vetor a ser ordenado. Para o algoritmo de Euclides o tamanho da entrada pode ser considerado o número de bits para representar cada um dos dois números que este recebe de entrada.
34 Contando o tempo no problema de Ordenação Ordenação de Vetores por Inserção 1 Entrada: V # execuções 2 Para j=2 até n faça n 3 valor_atual = j n-1 4 i = j-1 n-1 5 Enquanto i 1 e V i > valor_atual faça 6 V i+1 = V i 7 i = i 1 8 V i+1 = valor_atual n-1 9 Saída: V c i é o número de repetições do laço interno para aquele valor de i
35 Contando o tempo no problema de Ordenação
36 Melhor Caso
37 Pior Caso
38 Complexidade Assintótica Geralmente a análise de complexidade de um algoritmo é feita para o pior caso, embora não seja incomum fazer TAMBÉM uma análise de melhor caso. Além disso, na maioria dos casos interessa fazer uma análise de comportamento assintótico para os algoritmos (análise com instâncias MUITO grandes). Esse estudo tem a vantagem de simplificar a notação de complexidade utilizada para medir o desempenho do algoritmo.
39 Complexidade Assintótica Levando em conta a complexidade do algoritmo de ordenação, (3*n 2 + 7*n -8)/2, vamos comparar essa complexidade com função 3*n 2 para diversos valores de n: n 3*n 2 + 7*n - 8 3*n
40 Complexidade Assintótica Podemos perceber que a importância do termo linear da função diminui conforme n aumenta. Então, em uma análise assintótica em que n tende a infinito, podemos nos concentrar apenas no termo dominante da função de complexidade. n 3*n 2 + 7*n - 8 3*n
41 Notações Assintóticas: classe O Define o limitante superior da complexidade assintótica do algoritmo. Para uma função f(n) que define a complexidade de um algoritmo, ele é O(g(n)) se 0 f(n) c.g(n) para algum c e para todo n n 0. Diz-se que se f(n) tem complexidade O(g(n)) então ele cresce no máximo tão rapidamente quanto g(n).
42 Notações Assintóticas: classe O
43 Notações Assintóticas: classe Ω Define o limitante inferior da complexidade assintótica do algoritmo. Para uma função f(n) que define a complexidade de um algoritmo, ele é Ω(g(n)) se 0 c.g(n) f(n) para algum c e para todo n n 0. Diz-se que se f(n) tem complexidade Ω(g(n)) então ele cresce no mínimo tão lentamente quanto g(n).
44 Notações Assintóticas: classe Ω
45 Notações Assintóticas: classe Θ Define um limitante estrito da complexidade assintótica do algoritmo. Para uma função f(n) que define a complexidade de um algoritmo, ele é Θ(g(n)) se c 1.g(n) f(n) c 2.g(n) para algum c 1, c 2 e para todo n n 0. Diz-se que se f(n) tem complexidade Θ(g(n)) então ele cresce tanto quanto g(n).
46 Notações Assintóticas: classe Θ
47 Recorrência Mas e quanto a complexidade do algoritmo de Euclides? Para efetuar a contagem de operações necessárias nesse caso, vamos reescrever o algoritmo de uma forma recursiva.
48 Recorrência Algoritmo de Euclides Recursivo 1 Entrada: a, b 2 Se a b faça 3 Se a > b então 4 Retorne Euclides(a mod b, b) 5 Senão 6 Retorne Euclides(a, b mod a) 7 Senão 8 Retorne a 9 Saída: a
49 Recorrência Algoritmo de Euclides Recursivo 1 Entrada: a, b com a > b 2 Se a b faça 1 3 Retorne Euclides(b,a mod b) 7 Senão 1 8 Retorne a 1 # execuções T(b,a mod b) 9 Saída: a Utilizar divisão requer menor número de passos (subtração agrupada) Dado que a > b, a mod b = r < b e o primeiro parâmetro sempre será maior que o segundo.
50 Recorrência Algoritmo de Euclides Recursivo 1 Entrada: a, b com a > b 2 Se a b faça 1 3 Retorne Euclides(b,a mod b) 7 Senão 1 8 Retorne a 1 # execuções T(b,a mod b) 9 Saída: a O número de execuções depende da função T(b, a mod b), que é uma função recursiva.
51 Recorrência Método da Iteração O número de execuções depende da função T(a, b), que é uma função recursiva. Denotando a mod b como r 0 e sabemos também que: T(a,b) = 1 + T(b, r 0 ) = 2 + T(r 0, r 1 ) = = N + T(r N-2, r N-1 ) = N + 1 T(a,0) = 0
52 Recorrência Método da Iteração Supondo que leva-se N passos para chegar ao final se fizermos N=1 temos que: T(a,b) = 1 => e b divide a com resto igual a 0. Os menores números em que isso é possível é a=2 e b=1* *lembre-se: a > b sempre!!
53 Recorrência Método da Iteração Fazendo N=2 temos que: T(a,b) = 2 => e b divide a com resto diferente de 0 na primeira recursão. Os menores números em que isso é possível é a=3 e b=2* *b=1 levaria a apenas uma recursão.
54 Recorrência Método da Iteração Fazendo N=3 temos que: T(a,b) = 3 => e b divide a com resto maior que 1 na primeira recursão. Os menores números em que isso é possível é a=5 e b=3* *b=2 levaria a apenas duas recursões, pois todo resto da divisão por 2 é 1 e apenas com a=5 teríamos resto 2.
55 Recorrência Método da Iteração Prosseguindo chegamos a: N a b Eu conheço essa sequência!
56 Recorrência Método da Iteração Logo, dado uma quantidade N de recursões, os menores números a e b que levam a essa quantidade são os números de fibonacci F N+2 e F N+1, respectivamente. (prova por indução)
57 Recorrência Método da Iteração Então, se o algoritmo requer N passos para completar, o valor de b deve ser maior ou igual a F N+1. F N+1 ϕ N-1 => b ϕ N-1 => log(b) (N-1)log(ϕ) => log(b)/(n-1) log(ϕ) Como log(ϕ) > 1/5: log(b)/(n-1) > 1/5 => 5log(b) > N-1 => 5log(b) N
58 Recorrência Método da Iteração Logo, o número máximo de recursão N é proporcional ao número de dígitos do número b: O(log(b)). Esse algoritmo é então O(logn) em relação ao número de dígitos do segundo parâmetro.
59 Recorrência Árvore de Recorrência Suponha uma função de recorrência da seguinte forma: T(n) = n 3 + 2*T(n/3) T(1) = 1 (n/3) 3 Se construírmos uma árvore desmembrando as recursões, teremos: n 3 (n/3) 3 (n/9) 3 (n/9) 3 (n/9) 3 (n/9) 3 (n/27) 3 (n/27) 3 (n/27) 3 (n/27) 3.. (n/27) 3 (n/27) 3 (n/27) 3 (n/27) 3.
60 Recorrência Árvore de Recorrência n 3 (n/3) 3 (n/3) 3 (n/9) 3 (n/9) 3 (n/9) 3 (n/9) 3 (n/27) 3 (n/27) 3 (n/27) 3 (n/27) 3.. (n/27) 3 (n/27) 3 (n/27) 3 (n/27) 3.
61 Recorrência Árvore de Recorrência n 3 (n/3) 3 (n/3) 3 (n/9) 3 (n/9) 3 (n/9) 3 (n/9) 3 (n/27) 3 (n/27) 3 (n/27) 3 (n/27) 3... (n/27) 3 (n/27) 3 (n/27) 3 (n/27) 3
Projeto e Análise de Algoritmos
Projeto e Análise de Algoritmos A. G. Silva Baseado nos materiais de Souza, Silva, Lee, Rezende, Miyazawa Unicamp Ribeiro FCUP 18 de agosto de 2017 Conteúdo programático Introdução (4 horas/aula) Notação
Elementos de Análise Assintótica
Elementos de Análise Assintótica Marcelo Keese Albertini Faculdade de Computação Universidade Federal de Uberlândia 23 de Março de 2018 Aula de hoje Nesta aula veremos: Elementos de Análise Assintótica
ANÁLISE DE ALGORITMOS: PARTE 3
ANÁLISE DE ALGORITMOS: PARTE 3 Prof. André Backes 2 A notação grande-o é a forma mais conhecida e utilizada de análise Complexidade do nosso algoritmo no pior caso Seja de tempo ou de espaço É o caso mais
Teoria da Computação Aula 9 Noções de Complexidade
Teoria da Computação Aula 9 Noções de Complexidade Prof. Esp. Pedro Luís Antonelli Anhanguera Educacional Análise de um Algoritmo em particular Qual é o custo de usar um dado algoritmo para resolver um
André Vignatti DINF- UFPR
Notação Assintótica: Ω, Θ André Vignatti DINF- UFPR Limitantes Inferiores Considere o seguinte trecho de código: void main () { /* trecho que le N da entrada padrao */ for (i = 0 ; i< N; i++) puzzle(i);
4º 20/10/2003. ÍNDICE
Universidade Federal de Juiz de Fora UFJF. Departamento de Ciência da Computação DCC. Curso de Ciência da Computação. Análise e Projeto de Algoritmos 4º período. Filippe Jabour. Atualizado em 20/10/2003.
Análise de Algoritmos Estrutura de Dados II
Centro de Ciências Exatas, Naturais e de Saúde Departamento de Computação Análise de Algoritmos Estrutura de Dados II COM10078 - Estrutura de Dados II Prof. Marcelo Otone Aguiar [email protected]
Aula 1. Teoria da Computação III
Aula 1 Teoria da Computação III Complexidade de Algoritmos Um problema pode ser resolvido através de diversos algoritmos; O fato de um algoritmo resolver um dado problema não significa que seja aceitável
Busca Binária. Aula 05. Busca em um vetor ordenado. Análise do Busca Binária. Equações com Recorrência
Busca Binária Aula 05 Equações com Recorrência Prof. Marco Aurélio Stefanes marco em dct.ufms.br www.dct.ufms.br/ marco Idéia: Divisão e Conquista Busca_Binária(A[l...r],k) 1:if r < lthen 2: index = 1
Complexidade Assintótica de Programas Letícia Rodrigues Bueno
Complexidade Assintótica de Programas Letícia Rodrigues Bueno Análise de Algoritmos 1. Introdução; Análise de Algoritmos 1. Introdução; 2. Conceitos básicos; Análise de Algoritmos 1. Introdução; 2. Conceitos
Medida do Tempo de Execução de um Programa. David Menotti Algoritmos e Estruturas de Dados II DInf UFPR
Medida do Tempo de Execução de um Programa David Menotti Algoritmos e Estruturas de Dados II DInf UFPR Classes de Comportamento Assintótico Se f é uma função de complexidade para um algoritmo F, então
Introdução à Análise Algoritmos
Introdução à Análise Algoritmos Notas de aula da disciplina IME 4-182 Estruturas de Dados I Paulo Eustáquio Duarte Pinto (pauloedp arroba ime.uerj.br) abril/218 Ordenação por SELEÇÃO: Idéia: Dado um vetor
Projeto e Análise de Algoritmos
Projeto e Análise de Algoritmos Aula 01 Complexidade de Algoritmos Edirlei Soares de Lima O que é um algoritmo? Um conjunto de instruções executáveis para resolver um problema (são
ANÁLISE DE ALGORITMOS
ANÁLISE DE ALGORITMOS Paulo Feofiloff Instituto de Matemática e Estatística Universidade de São Paulo agosto 2009 Introdução P. Feofiloff (IME-USP) Análise de Algoritmos agosto 2009 2 / 102 Introdução
Medida do Tempo de Execução de um Programa
Medida do Tempo de Execução de um Programa Livro Projeto de Algoritmos Nívio Ziviani Capítulo 1 Seção 1.3.1 http://www2.dcc.ufmg.br/livros/algoritmos/ Comportamento Assintótico de Funções O parâmetro n
Lista de Exercícios 6: Soluções Funções
UFMG/ICEx/DCC DCC Matemática Discreta Lista de Exercícios 6: Soluções Funções Ciências Exatas & Engenharias o Semestre de 06 Conceitos. Determine e justifique se a seguinte afirmação é verdadeira ou não
CT-234. Estruturas de Dados, Análise de Algoritmos e Complexidade Estrutural. Carlos Alberto Alonso Sanches
CT-234 Estruturas de Dados, Análise de Algoritmos e Complexidade Estrutural Carlos Alberto Alonso Sanches Bibliografia T.H. Cormen, C.E. Leiserson and R.L. Rivest Introduction to algorithms R. Sedgewick
Análise de algoritmos. Parte I
Análise de algoritmos Parte I 1 Recursos usados por um algoritmo Uma vez que um procedimento está pronto/disponível, é importante determinar os recursos necessários para sua execução Tempo Memória Qual
Complexidade de Tempo e Espaço
Complexidade de Tempo e Espaço Profa. Sheila Morais de Almeida DAINF-UTFPR-PG junho - 2018 Sheila Almeida (DAINF-UTFPR-PG) Complexidade de Tempo e Espaço junho - 2018 1 / 43 Este material é preparado usando
Lista de exercícios sobre contagem de operações Prof. João B. Oliveira
Lista de exercícios sobre contagem de operações Prof. João B. Oliveira 1. metodo m ( Vetor V ) int i, res = 0; para i de 1 a V.size res = res + V[i]; return res; Soma de elementos de um vetor, O( ). 2.
Comportamento assintótico
ANÁLISE DE ALGORITMOS: PARTE 2 Prof. André Backes 2 Na última aula, vimos que o custo para o algoritmo abaixo é dado pela função f(n) = 4n + 3 1 3 Essa é a função de complexidade de tempo Nos dá uma ideia
ALGORITMOS AVANÇADOS UNIDADE I Análise de Algoritmo - Notação O. Luiz Leão
Luiz Leão [email protected] http://www.luizleao.com Conteúdo Programático 1.1 - Algoritmo 1.2 - Estrutura de Dados 1.2.1 - Revisão de Programas em C++ envolvendo Vetores, Matrizes, Ponteiros, Registros
Estruturas de Dados 2
Estruturas de Dados 2 Recorrências IF64C Estruturas de Dados 2 Engenharia da Computação Prof. João Alberto Fabro - Slide 1/31 Recorrências Análise da Eficiência de Algoritmos: Velocidade de Execução; Análise
Solução de Recorrências
CENTRO FEDERAL DE EDUCAÇÃO TECNOLÓGICA DE MINAS GERAIS Solução de Recorrências Algoritmos e Estruturas de Dados I Natália Batista https://sites.google.com/site/nataliacefetmg/ [email protected]
COMPLEXIDADE DE ALGORITMOS
COMPLEXIDADE DE ALGORITMOS Algoritmos Seqüência de instruções necessárias para a resolução de um problema bem formulado Permite implementação computacional COMPLEXIDADE DE ALGORITMOS Um algoritmo resolve
03 Análise de Algoritmos (parte 3) SCC201/501 - Introdução à Ciência de Computação II
03 Análise de Algoritmos (parte 3) SCC201/501 - Introdução à Ciência de Computação II Prof. Moacir Ponti Jr. www.icmc.usp.br/~moacir Instituto de Ciências Matemáticas e de Computação USP 2010/2 Moacir
BCC202 - Estrutura de Dados I
BCC202 - Estrutura de Dados I Aula 06: Análise de Algoritmos (Parte 3) Reinaldo Fortes Universidade Federal de Ouro Preto, UFOP Departamento de Ciência da Computação, DECOM Website: www.decom.ufop.br/reifortes
Divisão e Conquista. Norton T. Roman. Apostila baseada nos trabalhos de Cid de Souza, Cândida da Silva e Delano M. Beder
Divisão e Conquista Norton T. Roman Apostila baseada nos trabalhos de Cid de Souza, Cândida da Silva e Delano M. Beder Divisão e Conquista Construção incremental Ex: Consiste em, inicialmente, resolver
Técnicas de análise de algoritmos
CENTRO FEDERAL DE EDUCAÇÃO TECNOLÓGICA DE MINAS GERAIS Técnicas de análise de algoritmos Algoritmos e Estruturas de Dados I Natália Batista https://sites.google.com/site/nataliacefetmg/ [email protected]
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
Introdução à Ciência da Computação II
Introdução à Ciência da Computação II 2semestre/200 Prof Alneu de Andrade Lopes Apresentação com material gentilmente cedido pelas profas Renata Pontin Mattos Fortes http://wwwicmcuspbr/~renata e Graça
Algoritmos e Estrutura de Dados. Aula 04 Recorrência Prof. Tiago A. E. Ferreira
Algoritmos e Estrutura de Dados Aula 04 Recorrência Prof. Tiago A. E. Ferreira Esta Aula... Nesta aula veremos três métodos para resolver recorrência: Método da substituição É suposto um limite hipotético
1 a Lista de Exercícios
Universidade Federal de Ouro Preto Instituto de Ciências Exatas e Biológicas Programa de Pós-Graduação em Ciência da Computação Projeto e Análise de Algoritmos - 1 o semestre de 2010 Professor: David Menotti
Projeto e Análise de Algoritmos
Projeto e Algoritmos Pontifícia Universidade Católica de Minas Gerais [email protected] 26 de Maio de 2017 Sumário A complexidade no desempenho de Quando utilizamos uma máquina boa, ela tende a ter
Lista 1 - PMR2300. Fabio G. Cozman 3 de abril de 2013
Lista 1 - PMR2300 Fabio G. Cozman 3 de abril de 2013 1. Qual String é impressa pelo programa: p u b l i c c l a s s What { p u b l i c s t a t i c void f ( i n t x ) { x = 2 ; p u b l i c s t a t i c void
É interessante comparar algoritmos para valores grandes de n. Para valores pequenos de n, mesmo um algoritmo ineficiente não custa muito para ser
É interessante comparar algoritmos para valores grandes de n. Para valores pequenos de n, mesmo um algoritmo ineficiente não custa muito para ser executado 1 Fazendo estimativas e simplificações... O número
Projeto e Análise de Algoritmos Aula 4: Dividir para Conquistar ou Divisão e Conquista ( )
Projeto e Análise de Algoritmos Aula 4: Dividir para Conquistar ou Divisão e Conquista (2.1-2.2) DECOM/UFOP 2013/1 5º. Período Anderson Almeida Ferreira Adaptado do material desenvolvido por Andréa Iabrudi
Análise de Algoritmos
Análise de Algoritmos Aula 04 Prof. Fernando Freitas Classes de Comportamento Assintótico Se f é uma função de complexidade para um algoritmo F, então O(f) é considerada a complexidade assintótica ou o
Análise de complexidade
Introdução Algoritmo: sequência de instruções necessárias para a resolução de um problema bem formulado (passíveis de implementação em computador) Estratégia: especificar (definir propriedades) arquitectura
Rascunho. CI165 - Análise de algoritmos (rascunho alterado constantemente) André Guedes Departamento de Informática UFPR. 11 de junho de 2017
CI165 - Análise de algoritmos (rascunho alterado constantemente) André Guedes Departamento de Informática UFPR 11 de junho de 017 Sumário 1 Apresentação do Curso Problemas computacionais e algoritmos 4
Análise de Complexidade de Algoritmos
Análise de Complexidade de Algoritmos Algoritmos e Estruturas de Dados 2009/2010 Introdução Algoritmo: conjunto claramente especificado de instruções a seguir para resolver um problema Análise de algoritmos:
Análise e Projeto de Algoritmos
Análise e Projeto de Algoritmos Mestrado em Ciência da Computação Prof. Dr. Aparecido Nilceu Marana Faculdade de Ciências I think the design of efficient algorithms is somehow the core of computer science.
COMPLEXIDADE DE ALGORITMOS COMPLEXIDADE DE ALGORITMOS
COMPLEXIDADE DE ALGORITMOS Algoritmos Seqüência de instruções necessárias para a resolução de um prolema em formulado Permite implementação computacional COMPLEXIDADE DE ALGORITMOS Um algoritmo resolve
FACULDADE CAMPO LIMPO PAULISTA BACHARELADO EM CIÊNCIA DA COMPUTAÇÃO. Projeto a Análise de Algoritmos I Lista de Exercícios 1
FACULDADE CAMPO LIMPO PAULISTA BACHARELADO EM CIÊNCIA DA COMPUTAÇÃO Projeto a Análise de Algoritmos I Lista de Exercícios 1 Prof. Osvaldo. 1. Descreva alguns problemas associados ao emprego de metodologias
INE5403 FUNDAMENTOS DE MATEMÁTICA DISCRETA
INE5403 FUNDAMENTOS DE MATEMÁTICA DISCRETA PARA A COMPUTAÇÃO PROF. DANIEL S. FREITAS UFSC - CTC - INE Prof. Daniel S. Freitas - UFSC/CTC/INE/2007 p.1/30 3 - INDUÇÃO E RECURSÃO 3.1) Indução Matemática 3.2)
Teoria dos Grafos. Valeriano A. de Oliveira Socorro Rangel Departamento de Matemática Aplicada.
Teoria dos Grafos Valeriano A. de Oliveira Socorro Rangel Departamento de Matemática Aplicada [email protected], [email protected] Grafos e Algoritmos Preparado a partir do texto: Rangel, Socorro.
Complexidade de Algoritmos
Complexidade de Algoritmos! Uma característica importante de qualquer algoritmo é seu tempo de execução! é possível determiná-lo através de métodos empíricos, considerando-se entradas diversas! é também
Estruturas de Dados 2
Estruturas de Dados 2 Técnicas de Projeto de Algoritmos Dividir e Conquistar IF64C Estruturas de Dados 2 Engenharia da Computação Prof. João Alberto Fabro - Slide 1/83 Projeto de Algoritmos por Divisão
Lista de Exercícios 6 Funções
UFMG/ICEx/DCC DCC Matemática Discreta Lista de Exercícios 6 Funções Ciências Exatas & Engenharias o Semestre de 06 Conceitos. Determine e justifique se a seguinte afirmação é verdadeira ou não para todas
Análise de Algoritmos e Estruturas de Dados
Análise de Algoritmos e Estruturas de Dados Guilherme Oliveira Mota CMCC - Universidade Federal do ABC [email protected] 21 de julho de 2018 Esta versão é um rascunho ainda em elaboração e não foi revisado
Complexidade de algoritmos Notação Big-O
Complexidade de algoritmos Notação Big-O Prof. Byron Leite Prof. Tiago Massoni Engenharia da Computação Poli - UPE Motivação O projeto de algoritmos é influenciado pelo estudo de seus comportamentos Problema
Construção de Algoritmos II Aula 06
exatasfepi.com.br Construção de Algoritmos II Aula 06 André Luís Duarte Porque mil anos são aos teus olhos como o dia de ontem que passou, e como a vigília da noite. Salmos 90:4 Recursividade e complexidade
INF 1010 Estruturas de Dados Avançadas
INF 1010 Estruturas de Dados Avançadas Complexidade de Algoritmos 2012 DI, PUC-Rio Estruturas de Dados Avançadas 2012.2 1 Introdução Complexidade computacional Termo criado por Hartmanis e Stearns (1965)
Análise e Complexidade de Algoritmos
Análise e Complexidade de Algoritmos Principais paradigmas do projeto de algoritmos - Recursividade - Tentativa e erro - Divisão e Conquista - Programação dinâmica - Algoritmos Gulosos e de Aproximação
Complexidade de Algoritmos
60 Desempenho 50 40 30 20 Algoritmo1 Algoritmo2 Algoritmo3 10 0 Complexidade de Algoritmos INFORMÁTICA BÁSICA Prof. Demétrios Coutinho C a m p u s P a u d o s F e r r o s D i s c i p l i n a d e A l g
7. Introdução à Complexidade de Algoritmos
7. Introdução à Complexidade de Algoritmos Fernando Silva DCC-FCUP Estruturas de Dados Fernando Silva (DCC-FCUP) 7. Introdução à Complexidade de Algoritmos Estruturas de Dados 1 / 1 Análise de Algoritmos
Complexidade Assintótica
Complexidade Assintótica 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] 08/2008 Material baseado
Aula 05: - Recursão (parte 1)
MCTA028 Programação Estruturada Aula 05: - Recursão (parte 1) Prof. Jesús P. Mena-Chalco [email protected] 3Q-20107 1 Recursão: Se você ainda não entendeu; Ver: "Recursão". Efeito Droste Anuncio
MCTA028 Programação Estruturada Aula 20 Exercícios de custos de um algoritmo
MCTA028 Programação Estruturada Aula 20 Exercícios de custos de um algoritmo Prof. Jesús P. Mena-Chalco Q-2017 1 Estudo de algoritmos O projeto de algoritmos é influenciado pelo estudo de seus comportamentos.
Algoritmos e Estruturas de Dados I (DCC/003) Estruturas Condicionais e de Repetição
Algoritmos e Estruturas de Dados I (DCC/003) Estruturas Condicionais e de Repetição 1 Comando while Deseja-se calcular o valor de: 1 + 2 + 3 +... + N. Observação: não sabemos, a priori, quantos termos
Aula 05: - Recursão (parte 1)
MCTA028 Programação Estruturada Aula 05: - Recursão (parte 1) Prof. João Henrique Kleinschmidt Material elaborado pelo prof. Jesús P. Mena-Chalco 3Q-20108 Recursão: Se você ainda não entendeu; Ver: "Recursão".
ANÁLISE DE COMPLEXIDADE DOS ALGORITMOS
1/18 ANÁLISE DE COMPLEXIDADE DOS ALGORITMOS Algoritmos 2/18 Algoritmos Algoritmo - sequência de instruções necessárias para a resolução de um problema bem formulado (passíveis de implementação em computador)
Teoria da Computação Aula 8 Noções de Complexidade
Teoria da Computação Aula 8 Noções de Complexidade Prof. Esp. Pedro Luís Antonelli Anhanguera Educacional Motivação: Por que estudar algoritmos? Perguntas: - Por que estudar algoritmos se os computadores
EEL470 Algoritmos e Estruturas de Dados Prof. Heraldo L. S. Almeida Prova 1 (22/05/2009)
1) Demonstre que, se f(n) Θ(g(n)) e g(n) O(h(n)), então h(n) Ω(f(n)). Valor: 2,0 pontos Se f(n) Θ(g(n)), então existem c 1, c 2 e n 1 tais que c 1 g(n) f(n) c 2 g(n), n n 1 Se g(n) O(h(n)), então existem
ANÁLISE DE ALGORITMOS: PARTE 4
ANÁLISE DE ALGORITMOS: PARTE 4 Prof. André Backes 2 Função recursiva Função que chama a si mesma durante a sua execução Exemplo: fatorial de um número N. Para N = 4 temos 4! = 4 * 3! 3! = 3 * 2! 2! = 2
1 a Lista Professor: Claudio Fabiano Motta Toledo Estagiário PAE: Jesimar da Silva Arantes
SSC0503 - Introdução à Ciência de Computação II 1 a Lista Professor: Claudio Fabiano Motta Toledo ([email protected]) Estagiário PAE: Jesimar da Silva Arantes ([email protected]) 1. O que significa
PCC104 - Projeto e Análise de Algoritmos
PCC104 - Projeto e Análise de Algoritmos Marco Antonio M. Carvalho Departamento de Computação Instituto de Ciências Exatas e Biológicas Universidade Federal de Ouro Preto 7 de outubro de 2016 Marco Antonio
Análise de Algoritmos
Análise de Algoritmos Estes slides são adaptações de slides do Prof. Paulo Feofiloff e do Prof. José Coelho de Pina. Algoritmos p. 1 Introdução CLRS 2.2 e 3.1 AU 3.3, 3.4 e 3.6 Essas transparências foram
Análise de Problemas Recursivos. Algoritmos e Estruturas de Dados Flavio Figueiredo (
Análise de Problemas Recursivos Algoritmos e Estruturas de Dados 2 2017-1 Flavio Figueiredo (http://flaviovdf.github.io) 1 Lembrando de Recursividade Procedimento que chama a si mesmo Recursividade permite
I. Correção de Algoritmos Não-Recursivos
I. Correção de Algoritmos Não-Recursivos Nos exercícios a seguir, você deverá demonstrar a correção dos algoritmos por meio dos conceitos vistos nos slides da Aula 03. 1) Prove que o seguinte algoritmo
Teoria da computabilidade Indecidíveis Decidíveis
Bacharelado em Ciência da Computação Disciplina: Algoritmos e Estruturas de Dados I Professor: Mário Luiz Rodrigues Oliveira Teoria da computabilidade Indecidíveis Decidíveis Teoria da complexidade Intratáveis:
2. Complexidade de Algoritmos
Introdução à Computação II 5952011 2. Complexidade de Algoritmos Prof. Renato Tinós Depto. de Computação e Matemática (FFCLRP/USP) 1 Principais Tópicos 2.1. Introdução 2.1.1. Revisão de Pseudo-Código 2.1.2.
Estruturas Discretas
Estruturas Discretas 2017.2 Marco Molinaro > Indução Forte Corretude de Algoritmos 1/20 Indução Forte > Indução Forte Corretude de Algoritmos 2/20 Indução Forte X Indução Fraca Para provar Propriedade
Análise de algoritmos Parte I
Parte I SCE-8 Introdução à Ciência da Computação II Rosane Minghim Algoritmo Noção geral: conjunto de instruções que devem ser seguidas para solucionar um determinado problema Cormen et al. (2002) Qualquer
Comportamento Assintótico. Algoritmos e Estruturas de Dados Flavio Figueiredo (http://flaviovdf.github.io)
Comportamento Assintótico Algoritmos e Estruturas de Dados 2 2017-1 Flavio Figueiredo (http://flaviovdf.github.io) 1 Até Agora Falamos de complexidade de algoritmos com base no número de passos Vamos generalizar
Fabio G. Cozman, Thiago Martins 2017
Lista 1 - adendo - PMR3201 Fabio G. Cozman, Thiago Martins 2017 Exercícios 1. (P1 2016) A listagem a seguir mostra o código de uma função que converte uma cadeia de caracteres com a representação decimal
Estruturas de Dados 2
Estruturas de Dados 2 Algoritmos de Ordenação em Tempo Linear IF64C Estruturas de Dados 2 Engenharia da Computação Prof. João Alberto Fabro - Slide 1/38 Algoritmos de Ordenação em Tempo Linear Limite Assintótico
