| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 优先级队列priority_queue模拟实现(含堆排向下、向上调整、仿函数) -> 正文阅读 |
|
[数据结构与算法]优先级队列priority_queue模拟实现(含堆排向下、向上调整、仿函数) |
优先级队列priority_queue也是队列的一种,可以理解为是排好序的队列,每增加一个数,内部就会自动排序,底层实现是通过堆排序实现的 图中可以发现,默认使用的容器是vector,既然底层是使用堆排序,那就需要频繁的通过下标访问,根据前面的了解,deque的访问速度是远不如vector的。less是仿函数,less是建大堆,可以更改仿函数让内部变成建小堆。 目录 一、向上、向下调整(默认建大堆)1、向上调整当我们在堆的末尾新增一个数据的时候,此时需要向上调整,核心思路是每一次都要和自己的父节点比较,如果新增数据比父节点更大,那就和父节点交换,子节点向上移动,同时计算出父节点的位置
2、向下调整向下调整的核心思路是,首先选出左右孩子中更大的那个,如果没有右孩子,那就默认左孩子最大;其次让更大的孩子和父节点比较,如果比父节点大,就交换,父节点移动到下一个节点,同时计算出子节点的位置
二、优先级队列priority_queue模拟实现下面是优先级队列的模拟实现,暂时没有加入仿函数,这里的模拟实现不支持list,如果使用迭代器是能够支持list的,但是太麻烦,用 [ ]?来的快一些。在实现之前,我们先看看priority有哪些需要实现的函数。 ?下面就依次来实现这些函数,最后使用这些函数来打印优先级队列中的内容 1、size():队列中元素的个数
2、empty():判断队列是否为空
3、front():返回根元素
4、push_back():尾插
?5、pop_back():头删(删除根节点)当我们pop的时候,根据队列的特性,默认是头删,也就是删除根节点,一旦删除了根节点,整个二叉树会崩溃,所以我们一般会先把根结点和最后一个结点交换,然后尾删,最后从根结点开始向下调整为大堆。
6、测试我们使用上述实现的函数来打印优先级队列中的内容
? ?三、优先级队列priority_queue模拟实现优化我们已经初步实现了优先级队列的一些功能,但是还剩下一个模板参数Compare没说 上面我们一直在模拟大堆的实现,但是如果我希望使用小堆实现呢??重新修改为小堆吗,这未免有点麻烦,所以模板参数Compare就是为了解决这个问题,在那之前我们需要了解仿函数 ? 1、仿函数其实本质上就是重载了运算符 (),类似于 [ ] 的重载
上面的只支持int类型,我们还可以把上面的改成模板的形式
2、优先级队列priority_queue模拟实现优化现在有了仿函数,我们可以在priority_queue所属的命名空间里加上上面写的Less结构体模板以及下面的Greater结构体模板,这样的话我们就可以在建大堆和小堆之间随意切换了
下面需要新增一个模板参数,同时稍微修改向上调整函数adjust_up、向下调整函数adjust_down,毕竟这两个函数决定了建大堆还是小堆 下面来依次测试一下建大堆(自上而下逐渐变小)和建小堆(自上而下逐渐变大) |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/4 16:59:56- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |