码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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​=k−1n0​−1​

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

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

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

  • 相关阅读:
    基于信号功率谱特征和GRNN广义回归神经网络的信号调制类型识别算法matlab仿真
    如何保留 Excel 表头和第一行数据并追加 CSV 数据
    VHDL菜鸟入门到精通之激励文件编写
    更改搜索路径上的文件夹
    【从零学Python】关于python下划线命名的事儿、enumerate()
    【老生谈算法】matlab实现LSB算法源码——LSB算法
    餐饮行业小程序开发|如何解决餐饮店遇到的难题?
    docker镜像编译与docker-compose部署与编排
    React 入门:使用脚手架写一个Hello组件
    linux安装mysql8超详细到每步命令
  • 原文地址:https://blog.csdn.net/weixin_45825865/article/details/126166137
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号