• 博客园logo
  • 会员
  • 周边
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • YouClaw
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
Williamzon
https://docs.python.org/2/library/index.html
博客园    首页    新随笔    联系   管理    订阅  订阅

.NET 集合类型性能分析

集合

Add

Insert

Remove

Item

Sort

Find

List<T>

如果集合重置大小,就是O(1)或O(n)

O(n)

O(n)

O(1)

O(n log n),最坏情况O(n^2)

 

Stack<T>

Push(),如果栈必须重置大小,就是O(1)或O(n)

n/a

Pop,O(1)

n/a

n/a

n/a

Queue<T>

Enqueue(),如果队列必须重置大小,就是O(1)或者O(n)

n/a

Dequeue,O(1)

n/a

n/a

n/a

HasSet<T>

如果必须重置大小,就是O(1)或O(n)

Add() ,O(1)或O(n)

O(1)

n/a

n/a

n/a

SortedSet<T>

如果必须重置大小,就是O(1)或O(n)

Add() ,O(1)或O(n)

O(1)

n/a

n/a

n/a

LinkedList<T>

AddLast(),O(1)

AddAfter(),O(1)

O(1)

n/a

n/a

O(n)

Dictionary<Tkey,Tvalue)

O(1)或O(n)

n/a

O(1)

O(1)

n/a

n/a

SortedDictionary<Tkey,Tvalue)

O(log n)

n/a

O(log n)

O(log n)

n/a

n/a

SortedList<Tkey,Tvalue)

无序数据为O(n);如果必须重置大小为O(n),到列表的尾部为O(log n)

n/a

O(n)

读写是O(log n);如果键在列表中,就是O(log n);如果键不在列表中O(n)

n/a

n/a

 

注:

O(1) 表示:无论集合中有多少数据项,这个操作需要的时间不变。

O(n) 表示:对于集合执行一个操作需要的时间在最坏情况时是N,表示随着元素的增加而线性增加。

O(log n)表示:操作需要的时间随着集合中元素的增加而增加,但每个元素需要的增加时间不是线性的,而是成对曲线的。

posted @ 2015-06-24 14:42  Williamzon  阅读(277)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2026
浙公网安备 33010602011771号 浙ICP备2021040463号-3