Know Thy Complexities! (Italiano)

Salve! Questa pagina web copre le complessità Big-O spaziali e temporali di algoritmi comuni usati in Informatica. Quando mi preparavo per i colloqui tecnici in passato, mi ritrovavo a passare ore a strisciare su internet per mettere insieme le complessità del caso migliore, medio e peggiore per gli algoritmi di ricerca e di ordinamento in modo da non essere bloccato quando mi venivano chieste informazioni. Nel corso degli ultimi anni, ho fatto colloqui in diverse startup della Silicon Valley, e anche in alcune aziende più grandi, come Google, Facebook, Yahoo, LinkedIn e Uber, e ogni volta che mi sono preparato per un colloquio, ho pensato tra me e me “Perché qualcuno non ha creato un bel foglio di calcolo Big-O? Così, per risparmiare a tutti voi un sacco di tempo, sono andato avanti e ne ho creato uno. Buon divertimento! – Eric

Guardate El Grapho, una libreria di visualizzazione di dati grafici che supporta milioni di nodi e bordi

Big-O Complexity Chart

Horrible Bad Fair Good Excellent
O(log n), O(1) O(n) O(n log n) O(n^2) O(2^n) O(n!) Elementi delle operazioni

Operazioni comuni della struttura dei dati

Struttura dei dati complessità temporale complessità spaziale
Media Peggiore Peggiore
Accesso Ricerca Inserimento Deliminazione Accesso Ricerca Inserimento Cancellazione
Array Θ(1) Θ(n) Θ(n) Θ(n) O(1) O(n) O(n) O(n) O(n)
Stack Θ(n) Θ(n) Θ(1) Θ(1) O(n) O(n) O(1) O(1) O(n)
Queueue Θ(n) Θ(n) Θ(1) Θ(1) O(n) O(n) O(1) O(1) O(n)
Singly-Linked List Θ(n) Θ(n) Θ(1) Θ(1) O(n) O(n) O(1) O(1) O(n)
Doubly-Linked List Θ(n) Θ(n) Θ(1) Θ(1) O(n) O(n) O(1) O(1) O(n)
Skip List Θ(log(n)) Θ(log(n)) Θ(log(n)) Θ(log(n)) O(n) O(n) O(n) O(n) O(n log(n))
Hash Table N/A Θ(1) Θ(1) Θ(1) N/A O(n) O(n) O(n) O(n)
Albero di ricerca binaria Θ(log(n)) Θ(log(n)) Θ(log(n)) Θ(log(n)) O(n) O(n) O(n) O(n) O(n)
Albero cartesiano N/A Θ(log(n)) Θ(log(n)) Θ(log(n)) N/A O(n) O(n) O(n) O(n)
B-Albero Θ(log(n)) Θ(log(n)) Θ(log(n)) Θ(log(n)) O(log(n)) O(log(n)) O(log(n)) O(log(n)) O(n)
Rosso-Albero nero Θ(log(n)) Θ(log(n)) Θ(log(n)) Θ(log(n)) O(log(n)) O(log(n)) O(log(n)) O(log(n)) O(n)
Splay Tree N/A Θ(log(n)) Θ(log(n)) Θ(log(n)) N/A O(log(n)) O(log(n)) O(log(n)) O(n)
Albero AVL Θ(log(n)) Θ(log(n)) Θ(log(n)) Θ(log(n)) O(log(n)) O(log(n)) O(log(n)) O(log(n)) O(n)
KD Tree Θ(log(n)) Θ(log(n)) Θ(log(n)) Θ(log(n)) O(n) O(n) O(n) O(n) O(n)

Algoritmi di ordinamento delle matrici

Algoritmo Complessità temporale Complessità spaziale
Migliore Media Peggiore Peggiore
Quicksort Ω(n log(n)) Θ(n log(n)) O(n^2) O(log(n))
Mergesort Ω(n log(n)) Θ(n log(n)) O(n log(n)) O(n)
Timsort Ω(n) Θ(n log(n)) O(n log(n)) O(n)
Heapsort Ω(n log(n)) Θ(n log(n)) O(n log(n)) O(1)
Bubble Sort Ω(n) Θ(n^2) O(n^2) O(1)
Insertion Sort Ω(n) Θ(n^2) O(n^2) O(1)
Selezione Ordina Ω(n^2) Θ(n^2) O(n^2) O(1)
Ordinamento ad albero Ω(n log(n)) Θ(n log(n)) O(n^2) O(n)
Shell Sort Ω(n log(n)) Θ(n(log(n))^2) O(n(log(n))^2) O(1)
Bucket Sort Ω(n+k) Θ(n+k) O(n^2) O(n)
Radix Sort Ω(nk) Θ(nk) O(nk) O(n+k)
Counting Sort Ω(n+k) Θ(n+k) O(n+k) O(k)
Cubesort Ω(n) Θ(n log(n)) O(n log(n)) O(n)

Impara di più

  • Cracking the Coding Interview: 150 domande di programmazione e soluzioni
  • Introduzione agli algoritmi, 3rd Edition
  • Data Structures and Algorithms in Java (2nd Edition)
  • High Performance JavaScript (Build Faster Web Application Interfaces)

Get the Official Big-O Poster ufficiale

Contribuenti

  1. Eric Rowell
  2. Quentin Pleple
  3. Michael Abed
  4. Nick Dizazzo
  5. Adam Forsyth
  6. Felix Zhu
  7. Jay Engineer
  8. Josh Davis
  9. Nodir Turakulov
  10. Jennifer Hamon
  11. David Dorfman
  12. Bart Massey
  13. Ray Pereda
  14. Si Pham
  15. Mike Davis
  16. mcverry
  17. Max Hoffmann
  18. Bahador Saket
  19. Damon Davison
  20. Alvin Wan
  21. Alan Briolat
  22. Drew Hannay
  23. Andrew Rasmussen
  24. Dennis Tsang
  25. Vinnie Magro
  26. Adam Arold
  27. Alejandro Ramirez
  28. Aneel Nazareth
  29. Rahul Chowdhury
  30. Jonathan McElroy
  31. steven41292
  32. Brandon Amos
  33. Joel Friedly
  34. Casper Van Gheluwe
  35. Eric Lefevre-.Ardant
  36. Oleg
  37. Renfred Harper
  38. Piper Chester
  39. Miguel Amigot
  40. Apurva K
  41. Matthew Daronco
  42. Yun-Cheng Lin
  43. Clay Tyler
  44. Orhan Can Ozalp
  45. Ayman Singh
  46. David Morton
  47. Aurelien Ooms
  48. Sebastian Paaske Torholm
  49. Koushik Krishnan
  50. Drew Bailey
  51. Robert Burke

Migliora questa pagina

Modifica queste tabelle!

Lascia un commento

Il tuo indirizzo email non sarà pubblicato. I campi obbligatori sono contrassegnati *