每个程序员都应该收藏的算法复杂度速查表
创始人
2024-03-01 17:18:17
0

算法复杂度这件事

这篇文章覆盖了计算机科学里面常见算法的时间和空间的 大 O ( Big-O ) 复杂度。我之前在参加面试前,经常需要花费很多时间从互联网上查找各种搜索和排序算法的优劣,以便我在面试时不会被问住。最近这几年,我面试了几家硅谷的初创企业和一些更大一些的公司,如 Yahoo、eBay、LinkedIn 和 Google,每次我都需要准备这个,我就在问自己,“为什么没有人创建一个漂亮的大 O 速查表呢?”所以,为了节省大家的时间,我就创建了这个,希望你喜欢!

Eric

图例

绝佳不错一般不佳糟糕

数据结构操作

数据结构时间复杂度空间复杂度
平均最差
访问搜索
ArrayO(1)O(n)
StackO(n)O(n)
Singly-Linked ListO(n)O(n)
Doubly-Linked ListO(n)O(n)
Skip ListO(log(n))O(log(n))
Hash Table-O(1)
Binary Search TreeO(log(n))O(log(n))
Cartesian Tree-O(log(n))
B-TreeO(log(n))O(log(n))
Red-Black TreeO(log(n))O(log(n))
Splay Tree-O(log(n))
AVL TreeO(log(n))O(log(n))

数组排序算法

算法时间复杂度空间复杂度
最佳平均
QuicksortO(n log(n))O(n log(n))
MergesortO(n log(n))O(n log(n))
TimsortO(n)O(n log(n))
HeapsortO(n log(n))O(n log(n))
Bubble SortO(n)O(n^2)
Insertion SortO(n)O(n^2)
Selection SortO(n^2)O(n^2)
Shell SortO(n)O((nlog(n))^2)
Bucket SortO(n+k)O(n+k)
Radix SortO(nk)O(nk)

图操作

节点 / 边界管理存储增加顶点增加边界移除顶点移除边界查询
Adjacency listO(V+E)O(1)
Incidence listO(V+E)O(1)
Adjacency matrixO(V^2)O(V^2)
Incidence matrixO(VE)O(

堆操作

类型时间复杂度
Heapify
Linked List (sorted)-
Linked List (unsorted)-
Binary HeapO(n)
Binomial Heap-
Fibonacci Heap-

大 O 复杂度图表

Big O Complexity Graph

推荐阅读

贡献者

  1. Eric Rowell, creator of Concrete.js, an HTML5 Canvas Framework
  2. Quentin Pleple
  3. Michael Abed
  4. Nick Dizazzo
  5. Adam Forsyth
  6. David Dorfman
  7. Jay Engineer
  8. Jennifer Hamon
  9. Josh Davis
  10. Nodir Turakulov
  11. Bart Massey
  12. Vinnie Magro
  13. Miguel Amigot
  14. Drew Bailey
  15. Aneel Nazareth
  16. Rahul Chowdhury
  17. Robert Burke
  18. steven41292
  19. Brandon Amos
  20. Mike Davis
  21. Casper Van Gheluwe
  22. Joel Friedly
  23. Oleg
  24. Renfred Harper
  25. Piper Chester
  26. Eric Lefevre-Ardant
  27. Jonathan McElroy
  28. Si Pham
  29. mcverry
  30. Max Hoffmann
  31. Alejandro Ramirez
  32. Damon Davison
  33. Alvin Wan
  34. Alan Briolat
  35. Drew Hannay
  36. Andrew Rasmussen
  37. Dennis Tsang
  38. Bahador Saket

相关内容

人工智能产业日报(05.2...
公司动态 华为“韬(τ)定律”引爆热点,寒武纪市值突破900...
2026-05-26 14:53:47
AI谄媚:别被甜言蜜语“惯...
陪孩子学习时,我发现了一个有意思的现象。一个小学三年级的孩子,认真...
2026-05-19 11:02:32
蚂蚁百灵开源Ring-2....
钛媒体App 5月15日消息,蚂蚁百灵宣布开源旗舰推理模型Ring...
2026-05-15 22:20:22
英维克涨6.39%,开源证...
今日英维克(002837)涨6.39%,收盘报106.38元。 2...
2026-05-13 23:57:54
人机博弈背后的战略推理:推...
Gabriele Farina成长于意大利北部一个盛产葡萄酒的丘陵...
2026-05-09 10:35:22
恒拓开源:4月10日融资买...
证券之星消息,4月10日,恒拓开源(920415)融资买入112....
2026-04-13 13:52:32

热门资讯

为什么计量 IT 的生产力如此... 在某些行业里,人们可以根据一些测量标准判定一个人的生产力。比如,如果你是一个零件制造商,可以通过一个...
硬核观察 #885 苹果 AR... 苹果 AR 眼镜被无限期推迟据报道,由于技术上的挑战,苹果公司已经无限期推迟了其轻型增强现实(AR)...
8 个提升你的隐私防护的开源密... 使用一些顶级开源密码管理器,确保你的登录凭证安全无虞。密码管理器是一项非常有用的实用程序。在你想寻找...
值得收藏的 27 个机器学习的... 机器学习 ( Machine Learning ) 有很多方面,当我开始研究学习它时,我发现了各种各...
PHP最佳实践(译) 简介PHP是一门复杂的语言,经过多年折腾,使其不同版本之间高度不一致,有时还有些bug。 每个版本都...
8个有趣的Linux提示与技巧... 我们时不时给你带来关于Linux的提示与技巧。和这个系列保持一致,这里有8个我们从读者收到最有趣的提...
Helix:高级 Linux ... 说到 基于终端的文本编辑器,通常 Vim、Emacs 和 Nano 受到了关注。这并不意味着没有其他...
2020 年的 GitHub ... 距离 2020 年结束只剩下区区 24 天,我们即将结束魔幻的 2020 ,迎来新的一年,新的一年或...
开源新闻速递:openSUSE... 今日关注openSUSE 项目组的 Dominique Leuenberger 在他的周报中说:“这...
如何在 Github 上创建一... 学习如何复刻一个仓库,进行更改,并要求维护人员审查并合并它。你知道如何使用 git 了,你有一个 G...