《算法导论》笔记 第17章 17.4 动态表

【笔记】


定义一个非空表T的装载因子α(T)为表中存储的元素个数除以表的大小后的结果。

动态表就是vector啦


表扩张


对push_back应用聚集分析:



得n次push_back操作的总代价为3n,平摊代价为3。


势能方法:

Φ(T)=2·num[T]-size[T]

刚完成一次扩张后,我们有num[T]=size[T]/2,于是Φ(T)=0。

在将要扩张前,有num[T]=size[T],于是Φ(T)=size[T]。

因为表至少半满,num[T]>=size[T]/2,因此Φ(T)>=0。

开始时有num[0]=size[T]=Φ(0)=0。

如果第i次push_back操作没有触发表扩张,则size[i]=size[i-1],平摊代价为

如果第i次push_back操作触发了一次扩张,则size[i]=2*size[i-1],且size[i-1]=num[i-1]=num[i]-1,即size[i]=2*(num[i]-1)ÿ

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值