数据结构算法分析 第一部分.ppt

  1. 1、本文档共80页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构算法分析 第一部分

* * * 若对相同数目的记录,在同样页块大小的情况下,比较2路,3路,6路归并 归并路数K 访问外存次数d 归并趟数S 2 132 3 3 108 2 6 72 1 结论:增加归并路数k,可减少归并趟数,从而减少总的读写磁盘次数d K是否越大越好? 磁盘文件的归并分类技术,分三部分来深入研究: K-路归并----减少文件归并遍数的方法,以减 少R/W次数 初始归并段的产生----研究一种比较好的产生 初始归并段的方法 缓冲区的处理----巧妙地运用缓冲区,以便使 I/O和CPU处理尽可能并行操作 K-路归并 1.归并路数k与归并趟数S的关系 2.归并路数与内部归并时间的关系 K-路归并 1.归并路数k与归并趟数S的关系 在2路归并中,初始归并段有m个,则归并树的层数为 归并的遍数为 「 log2m」 「 log2m」+1 ∵归并树第H层有m个记录(叶子) ∴m=2H-1 ∴H=「 log2m」+1 采用多路归并,可减少归并的遍数 如m=16即16个初始归并段,才采用4-路归并,归并遍数为2, 采用2路归并,归并遍数为4 m个初始归并段的K-路归并,所需的归并遍数为「 logkm」 K-路归并 2.归并路数与内部归并时间的关系 初始归并段的生成 This section treats the problem of creating initial runs as large as possible from a disk file,assuming a fixed amount of RAM is available for processing. Input Run File Input Buffer RAM Output Run File Output Buffer If the size of memory available for the array is M records,then the input file can be broken into initial runs of length M. Snowplow Movement 初始归并段的生成 ----置换与选择算法 (Replacement Selection) A better approach is to use an algorithm called Replacement Selection that,on average,creates runs that are 2M records in length. Existing snow Future snow Start time T Falling Snow 初始归并段的生成 ----置换与选择算法 (Replacement Selection) 例:输入文件FI各记录的关键码序列:17,21,05,44,10,12,56,32,29 按如下步骤执行选择与置换: (1)从输入文件FI中把K个记录读入内存中,并构造败者树(内存缓冲区的数组R可容纳k个记录) (2)利用败者树在R中选择一个关键码最小的记录r[q],把它作为门槛,其关键码存入Lastkey,以后再选出的关键码比它大的记录归入本归并段,比它小的归入下一归并段。 (3)将此r[q]记录写到输出文件FO中(q是叶结点序号) (4)若FI未读完,则从FI读入下一个记录,置换r[q]及败者树中的key[q] (5)调整败者树,从所有关键码比lastkey大的记录中选择一个关键码最小的记录r[q]作为门槛,其关键码 存入lastkey中 (6)重复(3)-(5),直到在败者树中选不出关键码比lastkey大的记录为止.此时,在输入文件FO中得到一个初始归并段,在它最后加一个归并段结束标志. (7)重复(2)-(6),重新开始选择和置换,产生新的初始归并段,直到输入文件FI中所有的记录选完为止. 试证明:置换选择排序法产生的初始归并段的长度至少为p(p为所用缓冲区的长度) 试问: (1)输入文件在什么状态下经由置换选择排序获得的初始顺串的长度最长? (2)又在什么情况下,出现最短的初始顺串?其最长或最短分别是多少? 并行操作的缓冲区处理 如果采用k路归并对k个归并段进行归并,至少需要k个输入缓冲区和1个输出缓冲区,每个缓冲

文档评论(0)

1444168621 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档