Quantidade de memória necessária
|
|
|
- Fernanda Avelar Fernandes
- 9 Há anos
- Visualizações:
Transcrição
1
2 Tempo de processamento Um algoritmo que realiza uma tarefa em 10 horas é melhor que outro que realiza em 10 dias Quantidade de memória necessária Um algoritmo que usa 1MB de memória RAM é melhor que outro que usa 1GB
3 Medir o tempo gasto por um algoritmo Não é uma boa opção Depende do compilador Pode preferir algumas construções ou otimizar melhor Depende do hardware GPU vs. CPU, desktop vs. smartphone Estudar o número de vezes que operações são executadas
4 Achar o máximo de um vetor int vmax(int *vec, int n) { int i; int max = vec[0]; for(i = 1; i < n; i++) { if(vec[i] > max) { max = vec[i]; } } return max; } Complexidade: f(n) = n1 Esse algoritmo é ótimo 1 n1 n1 A < n1 n1 n1 1
5 Análise de complexidade feita em função de n n indica o tamanho da entrada Número de elementos no vetor Número de vértices num grafo Número de linhas de uma matriz Diferentes entradas podem ter custo diferente Melhor caso Pior caso Caso médio
6 Recuperar um registro num arquivo procurando sequencialmente Quantos registros precisam ser processados em uma busca? Melhor caso: f(n) = 1 Pior caso: f(n) = n Caso médio: f(n) = (n+1)/2 Supondo que registros procurados estão presentes no arquivo e que registros são pesquisados com a mesma probabilidade
7 Problema: encontrar o valores minimo e máximo em um vetor 1 1 n1 n1 A < n1 n1 B < n1 void minmax(int *vec, int n, int *min, int *max) { int i; int *min = vec[0]; int *max = vec[0]; for(i = 1; i < n; i++) { if(vec[i] < *min) { *min = vec[i]; } if(vec[i] > *max) { *max = vec[i]; } } } melhor caso: f(n) = 2(n1) pior caso: f(n) = 2(n1) caso médio: f(n) = 2(n1)
8 Se vec[i] < *min, então não precisamos checar se vec[i] > *max 1 1 n1 n1 A < n1 n1a B < n1a void minmax2(int *vec, int n, int *min, int *max) { int i; int *min = vec[0]; int *max = vec[0]; for(i = 1; i < n; i++) { if(vec[i] < *min) { *min = vec[i]; } else { if(vec[i] > *max) { *max = vec[i]; } } } } melhor caso: (decrescente) f(n) = n1 pior caso: (crescente) f(n) = 2(n1) caso médio: (aleatório) f(n) > 3(n1)/2
9 Comparar elementos parapar Custo: n/2 comparações
10 Comparar elementos parapar Custo: n/2 comparações Elementos vermelhos são maiores que os azuis Encontrar o máximo entre os elementos vermelhos Custo: n/2 comparações Encontrar o mínimo entre os elementos azuis Custo: n/2 comparações
11 1 1 n/2 n/2 n/4 n/4 n/2 A < n/2 n/2 B < n/2 void minmax3(int *vec, int n, int *min, int *max) { int i; int *min = INT_MAX; int *max = INT_MIN; for(i = 0; i < n; i += 2) { if(vec[i] < vec[i+1]) { } } a = i; v = i+1; } else { a = i+1; v = i; } if(vec[a] < *min) *min = vec[a]; if(vec[v] > *max) *max = vec[v]; melhor caso: f(n) = 3n/2 pior caso: f(n) = 3n/2 caso médio: f(n) = 3n/2 Algoritmo ótimo
12 Algoritmo f(n) Melhor caso Pior caso Caso médio MinMax1 2(n1) 2(n1) 2(n1) MinMax2 n1 2(n1) > 3(n1)/2 MinMax3 3n/2 3n/2 3n/2
13
14 Para valores suficientemente pequenos de n, qualquer algoritmo custa pouco para ser executado, mesmo os ineficientes Escolha de um algoritmo não é um problema crítico Logo, analisamos algoritmos para grandes valores de n Estudamos o comportamento assintótico das funções de complexidade de um programa (comportamento pra grandes valores de n)
15 Uma função f(n) domina assintoticamente outra função g(n) se existem duas constantes positivas c e m tais que, para n m, temos g(n) c f(n).
16 f(n) = n 2, g(n) = n f(n) domina assintoticamente g(n) c = 1, m = 0 g(n) 1 f(n) para todo n m = 0
17 f(n) = n 2, g(n) = (n+1) 2 f(n) e g(n) dominam assintoticamente uma à outra f(n) 1 g(n) para todo n m = 0 g(n) 4 f(n) para todo n m = 1
18 Definimos g(n) = O(f(n)) se f(n) domina assintoticamente g(n) Lê se g(n) é da ordem no máximo f(n) Quando dizemos que o tempo de execução de um programa T(n) = O(n 2 ), existem constantes c e m tais que T(n) cn 2 para n m
19 f(n) = (n+1) 2 = O(n 2 ) Pois (n+1) 2 4n 2, para n m = 1 f(n) = n 2 e g(n) = n n = O(n 2 ), (faça m = 0 e c = 1) Mas n 2 não é O(n) Suponha que existam c e m tais que para todo n m, n 2 cn Logo n c para todo n m, contradição
20 f(n) = 3n 3 + 2n 2 + n = O(n 3 ) Basta mostrar que f(n) 6n 3, para n m = 0 Podemos dizer que f(n) = 3n 3 + 2n 2 + n = O(n 4 ), mas essa afirmação é mais fraca que f(n) = O(n 3 ) f(n) = log 5 (n) = O(log(n)) log b (n) difere de log c (n) por uma constante log b (c) f(n) log 5 (e)log(n), para todo n m = 0
21
22 Imagine um programa com três fases A primeira com custo O(n) A segunda com custo O(n 2 ) A terceira com custo O(n log(n)) Aplicando a regra da soma O tempo de execução total do programa é O(n 2 )
23 Uma função g(n) é Ω(f(n)) se g(n) domina assintoticamente f(n) Notação O denota um limite superior e a notação Ω denota um limite inferior
24 f(n) = 3n 3 + 2n 2 + n = Ω(n 3 ) Basta mostrar que n 3 3n 3 + 2n 2 + n, para n m = 0 Podemos dizer que f(n) = 3n 3 + 2n 2 + n = Ω(n 2 ), mas essa afirmação é mais fraca que f(n) = Ω(n 3 )
25 Uma função g(n) é Θ(f(n)) se g(n) e f(n) dominam assintoticamente uma à outra Definição equivalente: g(n) = Θ(f(n)) se g(n) = O(n) e g(n) = Ω(f(n))
26 Notação O é um limite assintótico firme Diz que duas funções crescem de forma similar e que a diferença é constante
27 Prove que 4log 2 (n) + 16 = O(n) 4log 2 (n) + 16 n para n m = 64 = 2 6 Prove que 4log 2 (n) + 16 = O(log 2 n) 4log 2 (n) log 2 (n) para n m = n+1 = O(2 n ). Verdadeiro ou falso? Verdadeiro, faça c = 2 e m = 0 2 2n = O(2 n ). Verdadeiro ou falso? Falso. Prova: Suponha 2 2n c2 n, divida por 2 n e obtenha 2 n c
28 Por que falar o tempo de execução do algoritmo A é pelo menos O(2 n ) não faz sentido? Um algoritmo com tempo de execução O(2 n ) realiza no máximo c2 n operações. Falar que um algoritmo realiza pelo menos no máximo c2 n operações não faz sentido.
29 Prove que max(f(n), g(n)) = Θ(f(n) + g(n)) max(f(n), g(n)) 1(f(n) + g(n)) para n m = 0 max(f(n), g(n)) (1/2)(f(n) + g(n)), para n m = 0
30
31 Se f é uma função de complexidade para um algoritmo, então O(f) é considerada a complexidade assintótica do algoritmo Podemos comparar algoritmos usando suas complexidades assintóticas Um algoritmo O(n) é melhor do que um O(n 2 ) Algoritmos com a mesma complexidade assintótica são equivalentes
32 Às vezes, a constante da função de complexidade de um algoritmo importar Um algoritmo com complexidade 2n 2 é melhor do que um com complexidade 100n para valores de n menores que 50 Quando dois algoritmos têm a mesma complexidade assintótica, podemos desempatar usando a constante da função de complexidade
33 Complexidade constante Tempo de execução do algoritmo independe do tamanho da entrada Os passos do algoritmo são executados um número fixo de vezes Exemplo: determinar se um número é ímpar
34 Complexidade logarítmica Típico de algoritmos que dividem um problema transformandoo em problemas menores (dividir para conquistar) Tempo de execução pode ser considerado menor do que uma constante grande Quando n é um milhão, log(n) 20 A base do logarítmo tem impacto pequeno Exemplo: busca binária
35 Complexidade linear O algoritmo realiza um número fixo de operações sobre cada elemento da entrada Melhor situação para um algoritmo que processa n elementos de entrada e produz n elementos de saída Exemplo: busca sequencial, calcular fatorial
36 Típico de algoritmos que dividem um problema em subproblemas, resolve cada subproblema de forma independente, e depois combina os resultados Exemplo: ordenação (eficiente)
37 Complexidade quadrática Típico de algoritmos que operam sobre pares dos elementos de entrada Comumente em um anel dentro de outro Útil para resolver problemas de tamanhos relativamente pequenos Exemplos: ordenação (ineficiente), imprimir uma matriz
38 Complexidade cúbica Útil para resolver problemas pequenos Exemplo: multiplicação de matrizes
39 Complexidade exponencial Típicos de algoritmos que fazem busca exaustiva (força bruta) para resolver um problema Não são úteis do ponto de vista prático Quando n é 20, O(2 n ) é um milhão
40 Complexidade exponencial Pior do que O(c n ) Não são úteis do ponto de vista prático Quando n é 20, O(n!) é maior que 2 quintilhões
41
42 (tamanho)
43 Algoritmo polinomial no tempo de execução tem função de complexidade O(f(n)), onde f(n) é um polinômio Algoritmos polinomiais geralmente são obtidos através de um entendimento mais profundo da estrutura do problema Enquanto algoritmos exponenciais são típicos de soluções força bruta Um problema é considerado Intratável: se não existe algoritmo polinomial para resolvêlo Bem resolvido: se existe algoritmo polinomial para resolvêlo
44 Existem algoritmos de complexidade exponencial que são úteis Por exemplo, o algoritmo simplex tem pior caso de tempo de execução exponencial, mas na média executa muito mais rápido do que isso Infelizmente, estas exceções são incomuns e a maioria dos algoritmos exponenciais conhecidos não são muito úteis
45 Um caixeiro viajante deseja visitar n cidades de tal forma que sua viagem inicie e termine em uma mesma cidade Cada cidade deve ser visitada uma única vez Duas cidades i, j podem ser ligadas por uma estrada de comprimento c i,j O problema é encontrar a menor rota para a viagem
46 A figura abaixo mostra 4 cidades (c1, c2, c3 e c4) e os pesos nas arestas mostram os comprimentos de cada estrada O percurso c1, c3, c4, c2, c1 é a solução para o problema, cujo percurso total tem distância 24
47 Um algoritmo simples seria verificar todas as rotas e escolher a menor delas Há (n 1)! rotas possíveis e a distância total percorrida em cada rota envolve n adições, logo o número total de adições é n! No exemplo anterior teríamos 24 adições; se tivéssemos 50 cidades, o número de adições seria aproximadamente Em um computador que executa 10 9 adições por segundo, o tempo total para resolver o problema com 50 cidades seria maior do que séculos só para executar as adições
48
49 Determinar o tempo de execução de um algoritmo pode ser complexo Determinar a complexidade assintótica, sem preocupação com as constantes envolvidas, pode ser uma tarefa mais simples Análise de algoritmos utiliza técnicas de matemática discreta Manipulação de somas, produtos, permutações, coeficientes binomiais, equações de recorrência
50 Comando simples (atribuição, comparação, operação aritmética, acesso a memória): O(1) Sequência de comandos: máximo dos tempos de execução dos comandos Comando condicional: tempo dos comandos dentro do condicional mais o tempo pra testar a condição, que é O(1) Anel: Tempo de execução dos comandos do anel mais teste de parada (geralmente O(1)), multiplicado pelo número de iterações
51 Para funções não recursivas: Comece pelas funções que não chamam nenhuma outra função Depois analise funções que chamam apenas funções analisadas no passo anterior E assim sucessivamente até chegar ao programa principal (main)
52 1 n n 1 int soma_acumulada(int n) { int i; int acumulador = 0; for(i = 0; i < n; i++) { acumulador += i; } return acumulador; } Qual a função de complexidade do número de atribuições para o acumulador? Qual a ordem de complexidade da função soma_acumulada?
53 1 n n(n+1)/2? n(n+1)/2? 1 void exemplo(int n) { int i, j; int a = 0; for(i = 0; i < n; i++) for(j = n; j > i; j) a += i + j; exemplo1(n); } Qual a complexidade assintótica da função exemplo?
54 Encontre o menor valor no vetor Troqueo com o primeiro elemento V[0] Repita os passos acima com os n1 itens restantes, depois com os n2 restantes, até que reste apenas 1
55 n1 n1 n(n1)/2? n(n1)/2? A < n(n1)/2? n1 n1 n1 }( n void ordena(int *V, int int i, j, min, x; for(i = 0; i < n 1; i++) { min = i; for(j = i + 1; j < n; j++) ([ V[min if(v[j] < min = j; /* troca A[min] e A[i]: */ x = V[min]; V[min] = V[i]; V[i] = x; } } Qual a complexidade assintótica do número de comparações?
56 n n*n n*n n*n*n n*n*n // A, B e C sao vetores globais }( n void e1(int int i, j, k; for(i = 0; i < n; i++) for(j = 0; j < n; j++) { C[i][j] = 0; for(k = n1; k >= 0; k) { C[i][j] = C[i][j] + A[i][k] * B[k][j]; } } } } O que faz essa função? Qual sua complexidade assintótica?
57 1 n n(n+1)/2 n(n+1)/2 n(n1)/2 n(n1)/2 void e2(int n) { int i, j, x, y; x = y = 0; for(i = 1; i <= n; i++) { for(j = i; j <= n; j++) x = x + 1; for(j = 1; j < i; j++) y = y + 1; } }
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
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
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
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
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
Análise de Algoritmos
Análise de Algoritmos Parte 3 Prof. Túlio Toffolo http://www.toffolo.com.br BCC202 Aula 06 Algoritmos e Estruturas de Dados I Como escolher o algoritmo mais adequado para uma situação? (continuação) Exercício
É 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
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
Algoritmo. Exemplo. Definição. Programação de Computadores Comparando Algoritmos. Alan de Freitas
Algoritmos Programação de Computadores Comparando Algoritmos Um algoritmo é um procedimento de passos para cálculos. Este procedimento é composto de instruções que definem uma função Até o momento, vimos
Teoria da Computação. Aula 3 Comportamento Assintótico 5COP096. Aula 3 Prof. Dr. Sylvio Barbon Junior. Sylvio Barbon Jr
5COP096 Teoria da Computação Aula 3 Prof. Dr. Sylvio Barbon Junior 1 Sumário 1) Exercícios Medida de Tempo de Execução. 2) Comportamento Assintótico de Funções. 3) Exercícios sobre Comportamento Assintótico
Área que visa determinar a complexidade (custo) de um algoritmo, com isso é possível:
Área que visa determinar a complexidade (custo) de um algoritmo, com isso é possível: Comparar algoritmos: existem algoritmos que resolvem o mesmo tipo de problema. Determinar se o algoritmo é ótimo :
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
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)
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
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 prof. Alexandre César Muniz de Oliveira
ESTRUTURAS DE DADOS prof. Alexandre César Muniz de Oliveira 1. Introdução 2. Pilhas 3. Filas 4. Listas 5. Árvores 6. Grafos 7. Complexidade 8. Ordenação 9. Busca Sugestão bibliográfica: ESTRUTURAS DE DADOS
Análise de Complexidade de Algoritmos. mario alexandre gazziro
Análise de Complexidade de Algoritmos mario alexandre gazziro Definição A complexidade de um algoritmo consiste na quantidade de esforço computacional necessária para sua execução. Esse esforço é expresso
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
Algoritmos Avançados Análise de Complexidade
CCAE Centro de Ciências Aplicadas e Educação UFPB - Campus IV - Litoral Norte Algoritmos Avançados Análise de Complexidade COMPLEXIDADE DE ALGORITMOS Definição: A Complexidade de um Algoritmo consiste
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
Medida do Tempo de Execução de um Programa. Bruno Hott Algoritmos e Estruturas de Dados I DECSI UFOP
Medida do Tempo de Execução de um Programa Bruno Hott Algoritmos e Estruturas de Dados I DECSI UFOP Medida do Tempo de Execução de um Programa O projeto de algoritmos é fortemente influenciado pelo estudo
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
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
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]
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.
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 Medida do Tempo de Execução de um Programa O projeto de algoritmos é fortemente influenciado pelo
CES-11. Noções de complexidade de algoritmos. Complexidade de algoritmos. Avaliação do tempo de execução. Razão de crescimento desse tempo.
CES-11 Noções de complexidade de algoritmos Complexidade de algoritmos Avaliação do tempo de execução Razão de crescimento desse tempo Notação O Exercícios COMPLEXIDADE DE ALGORITMOS Importância de análise
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
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
BCC202 - Estrutura de Dados I
BCC202 - Estrutura de Dados I Aula 05: Análise de Algoritmos (Parte 2) ASN Universidade Federal de Ouro Preto, UFOP Departamento de Computação, DECOM Material elaborado com base nos slides do Prof. Reinaldo
Análise de algoritmos
Análise de algoritmos Introdução à Ciência de Computação II Baseados nos Slides do Prof. Dr. Thiago A. S. Pardo Análise de algoritmos Existem basicamente 2 formas de estimar o tempo de execução de programas
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
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.
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]
INF 1010 Estruturas de Dados Avançadas
INF 1010 Estruturas de Dados Avançadas Complexidade de Algoritmos 1 Introdução Complexidade computacional Termo criado por Juris Hartmanis e Richard Stearns (1965) Relação entre o tamanho do problema e
BCC202 - Estrutura de Dados I
BCC202 - Estrutura de Dados I Aula 05: Análise de Algoritmos (Parte 2) Reinaldo Fortes Universidade Federal de Ouro Preto, UFOP Departamento de Ciência da Computação, DECOM Website: www.decom.ufop.br/reifortes
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)
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
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
BC1424 Algoritmos e Estruturas de Dados I Aula 05 Custos de um algoritmo e funções de complexidade
BC1424 Algoritmos e Estruturas de Dados I Aula 05 Custos de um algoritmo e funções de complexidade Prof. Jesús P. Mena-Chalco 1Q-2016 1 1995 2015 2 Custo de um algoritmo e funções de complexidade Introdução
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
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
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
Complexidade assintótica de programas
Complexidade assintótica de programas Técnicas de análise de algoritmos são consideradas partes integrantes do processo moderno de resolver problemas, permitindo escolher, de forma racional, um dentre
Algoritmos e Estruturas de Dados I Aula 06 Custos de um algoritmo
Algoritmos e Estruturas de Dados I Aula 06 Custos de um algoritmo Prof. Jesús P. Mena-Chalco 1Q-2019 1 lista 3 7-2 6 NULL Node *Busca(int x, Node *lista) { while (lista!=null && lista->data!=x) lista =
Complexidade de Algoritmos
Complexidade de Algoritmos Complexidade de Algoritmos Definição A Complexidade de um Algoritmo consiste na quantidade de trabalho necessária para a sua execução, expressa em função das operações fundamentais,
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
Teoria dos Grafos Aula 7
Teoria dos Grafos Aula 7 Aula passada Implementação BFS DFS, implementação Complexidade Aplicações Aula de hoje Classe de funções e notação Propriedades da notação Funções usuais Tempo de execução Comparando
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
Análise e Complexidade de Algoritmos
Análise e Complexidade de Algoritmos Professor Ariel da Silva Dias Algoritmos Divisão e Conquista Construção incremental Resolver o problema para um sub-conjunto dos elementos de entrada; Então, adicionar
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
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
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
Melhores momentos AULA 1. Algoritmos p.38/86
Melhores momentos AULA 1 Algoritmos p.38/86 Definições x := inteiro i tal que i x < i + 1 x := inteiro j tal que j 1 < x j Exercício A1.B Mostre que n 1 2 n 2 n 2 e n 2 n 2 n + 1 2 para qualquer inteiro
Algoritmos 3/17/ Algoritmos como área de estudo e investigação
Algoritmos e Complexidade Ana Teresa Freitas INESC-ID/IST ID/IST 3/17/2005 1 O que é um algoritmo? Algoritmos: Sequência de instruções necessárias para a resolução de um problema bem formulado [passíveis
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
Medida do Tempo de Execução de um Programa. Bruno Hott Algoritmos e Estruturas de Dados I DECSI UFOP
Medida do Tempo de Execução de um Programa Bruno Hott Algoritmo e Etrutura de Dado I DECSI UFOP Clae de Comportamento Aintótico Se f é uma função de complexidade para um algoritmo F, então O(f) é coniderada
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
Análise de Algoritmos Parte 4
Análise de Algoritmos Parte 4 Túlio Toffolo [email protected] www.toffolo.com.br BCC202 Aula 07 Algoritmos e Estruturas de Dados I Como escolher o algoritmo mais adequado para uma situação? (continuação)
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
Técnicas de Projeto de Algoritmos
UNIVERSIDADE NOVE DE JULHO - UNINOVE Pesquisa e Ordenação Técnicas de Projeto de Algoritmos Material disponível para download em: www.profvaniacristina.com Profa. Vânia Cristina de Souza Pereira 03 _ Material
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
Introdução. Última alteração: 10 de Outubro de Transparências elaboradas por Charles Ornelas, Leonardo Rocha, Leonardo Mata e Nivio Ziviani
Introdução Última alteração: 10 de Outubro de 2006 Transparências elaboradas por Charles Ornelas, Leonardo Rocha, Leonardo Mata e Nivio Ziviani Projeto de Algoritmos Cap.1 Introdução Seção 1.1 1 Algoritmos,
Módulo 7. Complexidade de Algoritmos. Algoritmos e Estruturas de Dados II C++ Rone Ilídio
Módulo 7 Complexidade de Algoritmos Algoritmos e Estruturas de Dados II C++ Rone Ilídio Tempo de execução de um programa Qual algoritm executará mais rápido? int main(){ SYSTEMTIME inicio,fim; GetSystemTime(&inicio);
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);
MCTA028 Programação Estruturada Aula 19 Custos de um algoritmo e funções de complexidade
MCTA028 Programação Estruturada Aula 19 Custos de um algoritmo e funções de complexidade Prof. Jesús P. Mena-Chalco 3Q-2017 1 0 A = n-1... 2 0 A = n-1... - O programa funciona (está correto)? - Como medir/mensurar
Análise de Algoritmos
Análise de Algoritmos Parte 1 Prof. Túlio Toffolo http://www.toffolo.com.br BCC202 Aula 04 Algoritmos e Estruturas de Dados I Qual a diferença entre um algoritmo e um programa? Como escolher o algoritmo
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
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
Projeto de Algoritmos Introdução
Projeto de Algoritmos Introdução Última alteração: 30 de Agosto de 2010 Transparências elaboradas por Charles Ornelas Almeida, Israel Guerra e Nivio Ziviani Projeto de Algoritmos Cap.1 Introdução 1 Conteúdo
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
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
Classes, Herança e Interfaces
Escola de Artes, Ciências e Humanidades EACH-USP ACH2002 Introdução à Ciência da Computação II Professor: Delano Medeiros Beder revisada pelo professor: Luciano Digiampietri EACH Segundo Semestre de 2011
André Vignatti DINF- UFPR
Notação Assintótica: O André Vignatti DINF- UFPR Notação Assintótica Vamos expressar complexidade através de funções em variáveis que descrevam o tamanho de instâncias do problema. Exemplos: Problemas
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.
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:
Complexidade de Algoritmos
Complexidade de Algoritmos 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
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
5COP096 TeoriadaComputação
Sylvio 1 Barbon Jr [email protected] 5COP096 TeoriadaComputação Aula 13 Prof. Dr. Sylvio Barbon Junior Sumário - Problemas NP-Completo Algoritmos Não-deterministas; Classes NP-Completo e NP-Dificil; Teorema
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
Capítulo. Análise de Algoritmos. 6.1 Complexidade de Algoritmos 6.1
Capítulo 6 Análise de Algoritmos A eficiência (ou desempenho) de um programa é medida em termos do espaço de armazenamento e pelo tempo que ele utiliza para realizar uma tarefa. Mais precisamente, um programa
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.
Projeto e Análise de Algoritmos NP Completude. Prof. Humberto Brandão
Projeto e Análise de Algoritmos NP Completude Prof. Humberto Brandão [email protected] Universidade Federal de Alfenas versão da aula: 0.4 Introdução Problemas intratáveis ou difíceis são comuns
