8-15外部排序-最佳归并树

文件通过置换-选择排序后,得到了长度不等的初始归并段,通过最佳归并树来组织这些归并段,使得I/O最小

一.归并树

在这里插入图片描述
数字表示该归并段占的磁盘块数量

对初始归并段进行二路归并

合并R2和R1需要将5+1=6块的数据读入内存,需要读磁盘6次;将合并后的新归并段写回磁盘,需要6次的写操作
在这里插入图片描述

6和8的归并同样,需要读写各6+8=14次

在这里插入图片描述
完成
在这里插入图片描述
共需要读写各6+8+14+16=44次

将其看成是一棵二叉树,可以算的WPL=2×1+(5+1+6+2)×3=44=读磁盘次数=写磁盘次数

因此归并过程中的磁盘I/O次数=归并树的WPL×2

二.最佳归并树

1.二路归并使用哈夫曼树

在这里插入图片描述
此时WPL=6×1+5×2+2×3+(1+2)×4=34
读磁盘数=写磁盘数-34,总的磁盘I/O次数=68

2.多路归并:类似于哈夫曼树

(1)以3路归并段为例
对于
在这里插入图片描述
构造
在这里插入图片描述
归并过程中磁盘I/O次数446次

注:若减少一个归并段

初始
在这里插入图片描述
错误构造
在这里插入图片描述
可以看出,最后一次归并只是两路,不满足要求

因此,需要补充几个长度为0的“虚段”。

本题中添加一个长度为0的归并段,在构造k叉哈夫曼树时按0计算。

在这里插入图片描述
可以看出,度为0的结点数量等于初始归并段的个数

(2)计算添加虚段的个数

k叉最佳归并树应该只有度为0和度为k的结点,因此有n0+nk=n ①。又因为每个结点都带有一个叉,nk个分支结点的度均为k,共有k×nk个叉。除根结点外,每个结点都带有一个叉,因此k×nk=n-1 ②

联立①②有 n k = n 0 − 1 k − 1 n_k=\frac{n_0-1}{k-1} nk=k1n01

因为nk是整数,因此 n 0 − 1 k − 1 \frac{n_0-1}{k-1} k1n01也是整数

因此,若
(初始归并段的数量n0-1)%(k-1)=0,说明刚好可以构成严格k叉树

(初始归并段的数量n0-1)%(k-1)=u,说明需要补充(k-1-u)个虚段

如初始归并段数量为19的,构造8路归并,则需要补充3个虚段

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卡__卡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值