常见数据结构的查找、插入、删除时间复杂度
查找插入删除
【常见数据结构的查找、插入、删除时间复杂度】数组o(n)o(1)o(n)
有序数组o(lgn)o(n)o(n)
链表o(n)o(1)o(n)
有序链表o(n)o(n)o(n)
二叉树最坏o(n)o(n)o(n)
二叉树一般o(lgn)o(lgn)o(lgn)
平衡树o(lgn)o(lgn)o(lgn)
哈希表o(1)o(1)o(1)
(1)向一个有序数组中插入一个数的时间复杂度是多少?
查找插入位置如果用遍历查找的是O(n),用二分查找是O(log2n)。
但是数组的插入操作需要将插入位置后的元素全部后移一位,这需要O(n)。
所以总的时间复杂度是O(n)。(O(n)+O(n)=O(n),O(log2n)+O(n)=O(n))
(2) 有序链表查找的时间复杂度是O(n)的原因是什么?
折半查找对链表而言根本不能达到O(logN)的效率。只有当访问集合中任何一个元素的时间是常量O(1)时间时,折半查找才能达到O(logN),而链表访问其中元素的平均时间是O(N)即线性时间。对用数组构造的集合才能使用折半查找。
推荐阅读
- 热闹中的孤独
- JAVA(抽象类与接口的区别&重载与重写&内存泄漏)
- 放屁有这三个特征的,请注意啦!这说明你的身体毒素太多
- 一个人的旅行,三亚
- 布丽吉特,人生绝对的赢家
- 慢慢的美丽
- 尽力
- 一个小故事,我的思考。
- 家乡的那条小河
- 《真与假的困惑》???|《真与假的困惑》??? ——致良知是一种伟大的力量