|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Member
Iscritto dal: Oct 2005
Città: AP
Messaggi: 166
|
Analisi complessità algoritmo
Ho problemi a capire come si debba procedere per l'analisi della complessità degli algoritmi...
![]() ![]() Per il momento mi fermo al primo quesito... Per quale motivo per n <= 44 il tempo richiesto è una costante (che non dipende quindi da n) quando invece il ciclo for j:= 1 to n ... viene eseguito sempre a prescindere dalla dimensione di n? ![]() Grazie in anticipo. ![]()
__________________
The Grand essentials of happiness are: something to do, something to love, and something to hope for. |
![]() |
![]() |
![]() |
#2 |
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
Secondo me hanno invertito i 2 temini n>=44 e n<44 nella definizione di T(N)
Comunque direi anche io O(N) per n>44. Avranno dimenticato un nc2 per questo termine.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto. E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test. Ultima modifica di gugoXX : 31-08-2010 alle 10:22. |
![]() |
![]() |
![]() |
#3 |
Senior Member
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
|
da com'è fatta l'equazione di ricorrenza direi che hanno interpretato, sbagliando ovviamente, il for dentro l'if
|
![]() |
![]() |
![]() |
#4 |
Member
Iscritto dal: Oct 2005
Città: AP
Messaggi: 166
|
OK, passiamo ad un altro esercizio sperando la soluzione non sia errata anche questa...
[ESERCIZIO 1] http://www.cs.unibo.it/~vassura/ASD/...ASD_Feb_03.pdf http://www.cs.unibo.it/~vassura/ASD/svolgimento2.pdf Perchè la condizione n tra 2 e 10 non viene considerata?
__________________
The Grand essentials of happiness are: something to do, something to love, and something to hope for. |
![]() |
![]() |
![]() |
#5 |
Senior Member
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
|
ora che ci penso non è sbagliata.. se n <= 44 anche il ciclo di prima si può dire che è O(44) (il for i = 1 to n)
sono entrambe corrette, il motivo è lo stesso.. se c'è una limitazione superiore dell'input (cioè ti metti nel caso n <= k dove k è costante) allora qualcosa che è lineare in n diventa lineare in k.. e O(k) = O(1) pardon per la cazzata di prima :E |
![]() |
![]() |
![]() |
#6 |
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
Vabbe'.
Pero' allora una definizione tipo: Codice:
BubbleSort(array) = { n = params.length; for j = 1 to n-1 for k = 1 to j if array[k]<array[k+1] swap(array[j],array[j+1]; if n<100000000000 then BubbleSort = BubbleSort.Var(); else BubbleSort = 15 } Che se le la lunghezza dell'array e' >100000000000 allora e' O(c1) +O(n^2) = O(N^2) , mentre se e' <=100000000000 diciamo che e' O(N) , ovvero la varianza di tutti i valori dopo averli ordinati, che si puo' calcolare appunto in O(N), ignorando la prima parte data per costante perche' pari a O(100000000000 * 100000000000 /2)?
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto. E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test. Ultima modifica di gugoXX : 01-09-2010 alle 13:22. |
![]() |
![]() |
![]() |
#7 | |
Senior Member
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
|
Quote:
Ha piu' senso parlare (come fa l'esercizio) di T(n) per n <= 44, perche' ti serve per costruire il caso base, e la maggiorazione n <= c_1 aiuta a semplificare il ragionamento.
__________________
One of the conclusions that we reached was that the "object" need not be a primitive notion in a programming language; one can build objects and their behaviour from little more than assignable value cells and good old lambda expressions. —Guy Steele |
|
![]() |
![]() |
![]() |
#8 | |
Senior Member
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
|
Quote:
le costanti non contano asintoticamente, puoi aggiungere o togliere tutti gli zeri che vuoi da quei numeri, non cambia niente |
|
![]() |
![]() |
![]() |
#9 |
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
Quindi abbiamo un comodo metodo per trasformare tutti gli algoritmi che conosciamo in O(1)
![]()
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto. E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test. |
![]() |
![]() |
![]() |
#10 |
Senior Member
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
|
fammi un esempio allora
|
![]() |
![]() |
![]() |
#11 | |
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
Quello di prima.
BubbleSort modificato tale per cui se il numero di valori da ordinare e' inferiore a 100000000000 Quote:
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto. E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test. |
|
![]() |
![]() |
![]() |
#12 |
Senior Member
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
|
di solito si studia il caso pessimo |:
|
![]() |
![]() |
![]() |
#13 | |
Senior Member
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
|
Quote:
La definizione è: In questo caso ci rientri benissimo, visto che ti basta scegliere - spero di non commettere errori - c = n+1, n0 = n+1, g(n) = 1. La condizione è sempre vera, ed il tempo è asintoticamente "costante" - ossia, da un certo punto in poi non cambia mai. Ciò però ci dice che al più ci metterà sempre lo stesso tempo, ma non ci dice niente riguardo alla "bontà" di questo algoritmo in termini di tempo umano. Nel nostro caso la costante è così assurdamente grande che sarebbe un'aberrazione dire che quella complessità è "buona" per affrontare il problema. Ma resta costante. ciao ![]() P.S.: le (basse) costanti nascoste sono anche parte del motivo per cui il Quicksort (che nominalmente sarebbe quadratico, se guardiamo alla notazione in O grande) spesso è più performante di altri algoritmi come Heap sort e Merge sort, che invece sono n·log(n), per cui non c'è da stupirsi che vengano fuori risultati come questo! ![]()
__________________
C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai! Ultima modifica di DanieleC88 : 02-09-2010 alle 23:55. |
|
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 06:14.