容器类总览

1.vector
1). random access     --- 即得到第i个元素所花的时间为常数,与i无关。
2). varying length       --- 即长度可变,stl容器的共性,由库管理内存
3). amortized constant time insertion and deletions at the end
                                --- 即在vector尾部插入或删除所花的时间分配到每种情况下为常数。
    插入时涉及到内存分配问题,设vector.size()=N,当其capacity也为N时,在尾部插入数据时需要重新分配空间,这就涉及到数据拷贝问题,一般重新分配空间时都会以某种策略增长(如N的某个倍数),比如以2N,这样从N->2N,插入N个数据,只是开始拷贝了N个数据,以后并没有进行数据拷贝,只把相应数据插入vector尾部即可,消耗时间分摊一下为O(N/N),即为常数级。

2. deque
同vector,只是在队头队尾插入删除消耗时间分摊后也为常数。(循环队列实现?)

3. list
取第i个元素所花时间与N线性相关,在任何地方插入、删除时间为常数。

4 set、map
都属于sorted sociated container,里面的内容都是排序好的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值