Escolar Documentos
Profissional Documentos
Cultura Documentos
Algoritmos p. 1
Introduo
Algoritmos p. 2
Algoritmos p. 3
Sada: 11 Inverses: (1, 3), (2, 3), (4, 5), (2, 6), (4, 6), Inverses: (5, 6), (4, 7), (4, 8), (7, 8), (4, 9) e (7, 9).
Algoritmos p. 3
Nmero de inverses
CONTA-INVERSES (p, n) 1 c0 2 para i 1 at n 1 faa 3 para j i + 1 at n faa 4 se p[i] > p[j ] 5 ento c c + 1 6 devolva c
Algoritmos p. 4
Nmero de inverses
CONTA-INVERSES (p, n) 1 c0 2 para i 1 at n 1 faa 3 para j i + 1 at n faa 4 se p[i] > p[j ] 5 ento c c + 1 6 devolva c Se a execuo de cada linha de cdigo consome 1 unidade de tempo, o consumo total . . .
Algoritmos p. 4
Consumo de tempo
Se a execuo de cada linha de cdigo consome 1 unidade de tempo, o consumo total : linha 1 2 3 4 5 6 total todas as execues da linha = 1 = n n = i=2 i = (n + 2)(n 1)/2 n1 = i=1 i = n(n 1)/2 n1 i=1 i = n(n 1)/2 = 1
(3/2)n2 + n/2 + 1
Algoritmos p. 5
Consumo de tempo
Se a execuo de cada linha de cdigo consome 1 unidade de tempo, o consumo total : linha 1 2 3 4 5 6 total todas as execues da linha = 1 = n n = i=2 i = (n + 2)(n 1)/2 n1 = i=1 i = n(n 1)/2 n1 i=1 i = n(n 1)/2 = 1
(3/2)n2 + n/2 + 1
Consumo de tempo
Se a execuo de cada linha de cdigo consome um tempo diferente, o consumo total : linha todas as execues da linha 1 = 1 t1 t2 2 = n 3 = (n + 2)(n 1)/2 t3 t4 4 = n(n 1)/2 5 n(n 1)/2 t5 6 = 1 t6 total
?
Algoritmos p. 6
Consumo de tempo
Se a execuo de cada linha de cdigo consome um tempo diferente, o consumo total : linha 1 2 3 4 5 6 total todas as execues da linha = 1 = n = (n + 2)(n 1)/2 = n(n 1)/2 n(n 1)/2 = 1
=
t 3 +t 4 +t 5 2+ t n 2 2 c2 n 2 + c1 n + c 0 ,
t1 t2 t3 t4 t5 t6 n + (t1 t3 + t6 )
t 3 t 4 t 5 2
Consumo de tempo
Se a execuo de cada linha de cdigo consome um tempo diferente, o consumo total : linha 1 2 3 4 5 6 total todas as execues da linha = 1 = n = (n + 2)(n 1)/2 = n(n 1)/2 n(n 1)/2 = 1
=
t 3 +t 4 +t 5 2+ t n 2 2 c2 n 2 + c1 n + c 0 ,
t1 t2 t3 t4 t5 t6 n + (t1 t3 + t6 )
t 3 t 4 t 5 2
onde c2 , c1 e c0 so constantes que dependem da mquina. n2 para sempre! Est nas entranhas do algoritmo!
Algoritmos p. 7
Notao O
Intuitivamente. . .
O(f (n)) funes que no crescem mais rpido que f (n) funes menores ou iguais a um mltiplo de f (n) n2 (3/2)n2 9999n2 n2 /1000
etc.
Algoritmos p. 8
Notao O
Intuitivamente. . .
O(f (n)) funes que no crescem mais rpido que f (n) funes menores ou iguais a um mltiplo de f (n) n2 (3/2)n2 9999n2 n2 /1000
etc.
no
O(n2 )
Algoritmos p. 8
Definio
Sejam T (n) e f (n) funes dos inteiros nos reais. Dizemos que T (n) O(f (n)) se existem constantes positivas c e n0 tais que
T (n) c f (n)
para todo n n0 .
c f (n)
consumo de tempo
T (n)
n0
tamanho da entrada
Algoritmos p. 9
Mais informal
T (n) O(f (n)) se existe c > 0 tal que T (n) c f (n)
GRANDE.
c f (n) T (n)
n0
tamanho da entrada
Algoritmos p. 10
Exemplos
T (n) O(f (n)) l-se T (n) O de f (n) ou T (n) da ordem de f (n)
Algoritmos p. 11
Exemplos
T (n) O(f (n)) l-se T (n) O de f (n) ou T (n) da ordem de f (n)
Algoritmos p. 11
Exemplos
T (n) O(f (n)) l-se T (n) O de f (n) ou T (n) da ordem de f (n)
Algoritmos p. 11
Exemplos
T (n) O(f (n)) l-se T (n) O de f (n) ou T (n) da ordem de f (n)
Exemplo 1 10n2 O(n3 ). Prova: Para n 0, temos que 0 10n2 10 n3 . Outra prova: Para n 10, temos 0 10n2 n n2 = 1 n3 .
Algoritmos p. 11
Exemplos
T (n) O(f (n)) l-se T (n) O de f (n) ou T (n) da ordem de f (n)
Exemplo 1 10n2 O(n3 ). Prova: Para n 0, temos que 0 10n2 10 n3 . Outra prova: Para n 10, temos 0 10n2 n n2 = 1 n3 . Exemplo 2 lg n O(n).
Algoritmos p. 11
Exemplos
T (n) O(f (n)) l-se T (n) O de f (n) ou T (n) da ordem de f (n)
Exemplo 1 10n2 O(n3 ). Prova: Para n 0, temos que 0 10n2 10 n3 . Outra prova: Para n 10, temos 0 10n2 n n2 = 1 n3 . Exemplo 2 lg n O(n). Prova: Para n 1, tem-se que lg n 1 n.
Algoritmos p. 11
Mais exemplos
Exemplo 3 20n3 + 10n log n + 5 O(n3 ).
Algoritmos p. 12
Mais exemplos
Exemplo 3 20n3 + 10n log n + 5 O(n3 ). Prova: Para n 1, tem-se que
20n3 + 10n lg n + 5 20n3 + 10n3 + 5n3 = 35 n3 .
Algoritmos p. 12
Mais exemplos
Exemplo 3 20n3 + 10n log n + 5 O(n3 ). Prova: Para n 1, tem-se que
20n3 + 10n lg n + 5 20n3 + 10n3 + 5n3 = 35 n3 .
Algoritmos p. 12