首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >11.3 多路平衡归并的实现

11.3 多路平衡归并的实现

作者头像
小林C语言
发布2019-07-12 17:25:10
发布2019-07-12 17:25:10
6830
举报

01

多路平衡归并的实现

1、2-路归并:令u个记录分布在两个归并段上,按merge过程进行归并。每得到归并后的一个记录,仅需一次比较即可,则得到含u个记录的归并段需进行u-1次比较。

2、k-路归并:令u个记录分布在k个归并段上,显然,归并后的第一个记录应是k个归并段中关键字最小的记录,即应从每个归并段的第一个记录的相互比较中选出最小者,需要进行k-1次比较。每得到归并后的有序段中的一个记录,都要进行k-1次比较。显然为得到含u个记录的归并段需进行(u-1)(k-1)次比较。

3、由以上得,对n个记录的文件进行外排时,在内部归并过程中进行的总的比较次数为s(k-1)(n-1)。

4、若在进行k-路归并时利用“败者树”(Tree of Loser),则可使在k个记录中选出关键字最小的记录时仅需进行log2^k次比较。

5、败者树:是树形选择排序的一种变型。

如果您觉得本篇文章对您有作用,请转发给更多的人,点一下好看就是对小编的最大支持!

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-03-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 C语言入门到精通 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档