标签:
This webpage covers the space and time Big-O complexities of common algorithms used in Computer Science. When preparing for technical interviews in the past, I found myself spending hours crawling the internet putting together the best, average, and worst case complexities for search and sorting algorithms so that I wouldn’t be stumped when asked about them.
VisuAlgo.net. visualising data structures and algorithms through animation
Data Structure | Time Complexity | Space Complexity | |||||||
---|---|---|---|---|---|---|---|---|---|
Average | Worst | Worst | |||||||
Access | Search | Insertion | Deletion | Access | Search | Insertion | Deletion | ||
Array | O(1) | O(n) | O(n) | O(n) | O(1) | O(n) | O(n) | O(n) | O(n) |
Stack | O(n) | O(n) | O(1) | O(1) | O(n) | O(n) | O(1) | O(1) | O(n) |
Queue | O(n) | O(n) | O(1) | O(1) | O(n) | O(n) | O(1) | O(1) | O(n) |
Singly-Linked List | O(n) | O(n) | O(1) | O(1) | O(n) | O(n) | O(1) | O(1) | O(n) |
Doubly-Linked List | O(n) | O(n) | O(1) | O(1) | O(n) | O(n) | O(1) | O(1) | O(n) |
Skip List | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(n) | O(n) | O(n) | O(n) | O(n log(n)) |
Hash Table | N/A | O(1) | O(1) | O(1) | N/A | O(n) | O(n) | O(n) | O(n) |
Binary Search Tree | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(n) | O(n) | O(n) | O(n) | O(n) |
Cartesian Tree | N/A | O(log(n)) | O(log(n)) | O(log(n)) | N/A | O(n) | O(n) | O(n) | O(n) |
B-Tree | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(n) |
Red-Black Tree | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(n) |
Splay Tree | N/A | O(log(n)) | O(log(n)) | O(log(n)) | N/A | O(log(n)) | O(log(n)) | O(log(n)) | O(n) |
AVL Tree | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(n) |
KD Tree | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(n) | O(n) | O(n) | O(n) | O(n) |
Algorithm | Time Complexity | Space Complexity | ||
---|---|---|---|---|
Best | Average | Worst | Worst | |
Quicksort | O(n log(n)) | O(n log(n)) | O(n^2) | O(log(n)) |
Mergesort | O(nlog(n)) | O(nlog(n)) | O(nlog(n)) | O(n) |
Timsort | O(n) | O(nlog(n)) | O(nlog(n)) | O(n) |
Heapsort | O(nlog(n)) | O(nlog(n)) | O(nlog(n)) | O(1) |
Bubble Sort | O(n) | O(n^2) | O(n^2) | O(1) |
Insertion Sort | O(n) | O(n^2) | O(n^2) | O(1) |
Selection Sort | O(n^2) | O(n^2) | O(n^2) | O(1) |
Tree Sort | O(n log(n)) | O(n log(n)) | O(n^2) | O(n) |
Shell Sort | O(n log(n)) | O(n(log(n))^2) | O(n(log(n))^2) | O(1) |
Bucket Sort | O(n+k) | O(n+k) | O(n^2) | O(n) |
Radix Sort | O(nk) | O(nk) | O(nk) | O(n+k) |
Counting Sort | O(n+k) | O(n+k) | O(n+k) | O(k) |
Cubesort | O(n) | O(n log(n)) | O(n log(n)) | O(n) |
Data Structure | Time Complexity | ||||||
---|---|---|---|---|---|---|---|
Storage | Add Vertex | Add Edge | Remove Vertex | Remove Edge | Query | ||
Adjacency list | O(|V|+|E|) | O(1) | O(1) | O(|V| + |E|) | O(|E|) | O(|V|) | |
Incidence list | O(|V|+|E|) | O(1) | O(1) | O(|E|) | O(|E|) | O(|E|) | |
Adjacency matrix | O(|V|^2) | O(|V|^2) | O(1) | O(|V|^2) | O(1) | O(1) | |
Incidence matrix | O(|V| ? |E|) | O(|V| ? |E|) | O(|V| ? |E|) | O(|V| ? |E|) | O(|V| ? |E|) | O(|E|) |
Data Structure | Time Complexity | ||||||
---|---|---|---|---|---|---|---|
Find Max | Extract Max | Increase Key | Insert | Delete | Merge | ||
Binary Heap | O(1) | O(log(n)) | O(log(n)) | O(log(n)) | O(log(n)) | O(m+n) | |
Pairing Heap | O(1) | O(log(n)) |
O(log(n)) |
O(1) | O(log(n)) |
O(1) | |
Binomial Heap | O(1) |
O(log(n)) | O(log(n)) | O(1) |
O(log(n)) | O(log(n)) | |
Fibonacci Heap | O(1) | O(log(n)) |
O(1) |
O(1) | O(log(n)) |
O(1) |
Algorithm | Time Complexity | Space Complexity | |
---|---|---|---|
Average | Worst | Worst | |
Dijkstra’s algorithm | O(|E| log |V|) | O(|V|^2) | O(|V| + |E|) |
A* search algorithm | O(|E|) | O(b^d) | O(b^d) |
Prim’s algorithm | O(|E| log |V|) | O(|V|^2) | O(|V| + |E|) |
Bellman–Ford algorithm | O(|E| ? |V|) | O(|E| ? |V|) | O(|V|) |
Floyd-Warshall algorithm | O(|V|^3) | O(|V|^3) | O(|V|^2) |
Topological sort | O(|V| + |E|) | O(|V| + |E|) | O(|V| + |E| |
标签:
原文地址:http://blog.csdn.net/songzitea/article/details/52154174