数据结构C++——优先队列

文章目录

  • 一、定义
  • 二、ADT
  • 三、优先队列的描述
    • 3.1 线性表
    • 3.2 堆
      • 3.2.1 最大堆的ADT
      • 3.2.2 最大堆的插入
      • 3.2.3 最大堆的删除
      • 3.2.4 最大堆的初始化
    • 3.3 左高树 LT
      • 3.3.1 高度优先左高树HBLT
      • 3.3.2 重量优先左高树WBLT
      • 3.3.3 最大HBLT的插入
      • 3.3.4 最大HBLT的删除
      • 3.3.5 合并两棵最大HBLT
      • 3.3.6 初始化最大HBLT
  • 四、应用
    • 4.1 堆排序
    • 4.2 霍夫曼编码

一、定义

优先级队列(priority queue):

  • 0个或多个元素的集合
  • 每个元素都有一个优先级或值
  • 与FIFO结构的队列不同,优先级队列中元素出队列的顺序由元素的优先级决定。
  • 从优先级队列中删除元素是根据优先级高或低的次序,而不是元素进入队列的次序.
  • 优先级队列中的元素可以有相同的优先级

对优先级队列执行的操作有:

  • 查找一个元素(top)
  • 插入一个新元素(push)
  • 删除一个元素(pop)

两种优先级队列:

  • 最小优先级队列:“查找/删除” 操作用来“查找/删除”优先级最小的元素
  • 最大优先级队列:“查找/删除”操作用来“查找/删除”优先级最大的元素

二、ADT

实例:

  • 有限个元素集合
  • 每个元素都有一个优先级

操作(以最大优先级队列为例):

  • empty():判断优先级队列是否为空,为空时返回true
  • Size():返回队列中的元素数目
  • top():返回优先级最大的元素
  • pop():删除优先级最大的元素
  • push(x):插入元素x

三、优先队列的描述

3 种描述方法:

  • 线性表
  • 左高树

3.1 线性表

采用无序线性表来描述最大优先级队列

  • 数组描述(利用公式Location(i)=i-1)
    插入:表的右端末尾执行,时间: Θ ( 1 ) \Theta(1) Θ(1) ;
    删除: 查找优先级最大的元素,时间: Θ ( n ) \Theta(n) Θ(n);
  • 链表描述
    插入:在链头执行,时间: Θ ( 1 ) \Theta(1) Θ(1);
    删除: 查找优先级最大的元素, Θ ( n ) \Theta(n) Θ(n) ;

采用有序线性表描述最大优先级队列

  • 数组描述(利用公式Location(i)=i-1),元素按递增次序排列)
    插入:先查找插入元素的位置,时间: O(n) ;
    删除: 删除最右元素,时间: Θ ( 1 ) \Theta(1) Θ(1) ;
  • 链表描述(按递减次序排列)
    插入:先查找插入元素的位置,时间: O(n) ;
    删除: 表头删除,时间: Θ ( 1 ) \Theta(1) Θ(1) ;

3.2 堆

大/小根树

  • 每个节点的值都大于(小于)或等于其子节点(如果有的话)值的树
  • 大根树(max tree):又称最大树
  • 小根树(min tree):又称最小树
  • 大根树或小根树节点的子节点个数可以大于2

在这里插入图片描述

大根堆/小根堆

  • 既是大根树(小根树),又是完全二叉树
  • 大根堆(max heap):又称最大堆
  • 小根堆(min heap):又称最小堆

堆是完全二叉树,可用一维数组有效地描述堆。
关于完全二叉树,见本系列数据结构C++——二叉树和树

在这里插入图片描述

3.2.1 最大堆的ADT

数据成员:

  • T *heap; // 元素数组
  • int arrayLength; //数组的容量
  • int heapSize; //堆中的元素个数

方法:

  • empty():判断heapSize是否为0
  • Size():返回heapSize的值
  • top():如果 堆为空(heapSize==0),抛出异常queueEmpty;否则返回 heap[1](heap[0]未使用)
  • pop()
  • push(x)

重点:插入push、删除pop

3.2.2 最大堆的插入

流程:

  • 作为叶子节点插入最大堆
  • 与其父节点比较,若新插入节点更大,则两者交换(实际只是将父节点的值向下移)。否则该位置就是合法的,插入结束。
  • 若发生交换,则重复这个过程,直到位置合法/交换为根节点

在这里插入图片描述

代码实现:

template<class T>
maxHeap<T>& maxHeap<T>::push(const T& theElement)
{// 把theElement 插入到大根堆中if  (heapSize = = arrayLength-1) // 没有足够空间……//数组长度加倍//为theElement寻找应插入位置// currentNode 从新的叶节点开始,并沿着树上升int  currentNode = ++heapSize;while (currentNode != 1 && theElement > heap[currentNode/2]){//不能够把theElement放入heap[currentNode]heap[currentNode] = heap[currentNode/2]; // 将元素下移currentNode /= 2; // 移向父节点}heap[currentNode] = theElement;}

插入的时间复杂度:

  • 插入的时间复杂性.
    每一层的工作,耗时: Θ ( 1 ) \Theta(1) Θ(1)
  • 实现插入策略的时间复杂性:
    O ( h e i g h t ) = O ( l o g 2 n ) O(height) = O(log_2n) O(height)=O(log2n) (n 是堆的大小)

3.2.3 最大堆的删除

流程:

  • 删除heap[1]
  • 将最后一个元素heap[heapsize–]放到heap[1]的位置
  • 显然,此时不满足最大堆的性质
  • 因此,需要重新调整最大堆

调整为最大堆:

  • current初始化为1,指向根的位置,表示被替换的空位置
  • child 初始化为2,指向current的左孩子
  • lastElemet = 原来最大堆的最后一个元素
  • 循环判断:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/48142.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

QT总结——图标显示坑

最近写代码遇到一个神仙大坑&#xff0c;我都怀疑我软件是不是坏了&#xff0c;这里记录一下。 写qt工程的时候我们一般会设置图标&#xff0c;这个图标是窗体的图标同时也是任务栏的图标&#xff0c;但是我发现生成的exe没有图标&#xff0c;这个时候就想着给他加一个图标&…

AI学习记录 - 激活函数的作用

试验&#xff0c;通过在线性公式加入激活函数&#xff0c;可以拟合复杂的情况&#xff08;使用react实现&#xff0c;原创&#xff09; 结论:1、线性函数的叠加&#xff0c;无论叠加多少次&#xff0c;都是线性的 如下图 示例代码 线性代码&#xff0c;使用ykxb的方式&…

【BUG】已解决:ValueError: All arrays must be of the same length

ValueError: All arrays must be of the same length 目录 ValueError: All arrays must be of the same length 【常见模块错误】 【解决方案】 问题原因 解决方法 欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 欢迎来到我的主页&#xff0c;我是博主英杰&…

Python爬虫实战案例(爬取图片)

爬取图片的信息 爬取图片与爬取文本内容相似&#xff0c;只是需要加上图片的url&#xff0c;并且在查找图片位置的时候需要带上图片的属性。 这里选取了一个4K高清的壁纸网站&#xff08;彼岸壁纸https://pic.netbian.com&#xff09;进行爬取。 具体步骤如下&#xff1a; …

Ubuntu-文件管理器中鼠标右键添加文本文件

文件管理器中鼠标右键添加文本文件 一、概述二、步骤 一、概述 Ubuntu在文管右键发现没有创建文本文件的菜单&#xff0c; 期望如下所示&#xff0c;这样的操作非常简单 二、步骤 找到模板文件夹 在模板文件夹&#xff0c;创建自己想要的文件就好啦 这个也是支持放文件夹去…

【C++】学习笔记——哈希_1

文章目录 十八、哈希1. unordered系列关联式容器2. 底层结构哈希函数哈希冲突 未完待续 十八、哈希 1. unordered系列关联式容器 在C11中&#xff0c;STL又提供了4个unordered系列的关联式容器&#xff0c;这四个容器与红黑树结构的关联式容器使用方式基本类似&#xff0c;只…

Linux云计算 |【第二阶段】AUTOMATION-DAY1

主要内容&#xff1a; 版本控制&#xff08;集中式、分布式&#xff09;、Git基础&#xff08;服务端、客户端部署&#xff0c;基础命令操作、文档版本管理&#xff09;、Git进阶&#xff08;数据恢复、分支、冲突管理&#xff09; 一、版本控制概念 版本控制是一种记录文件变…

iterm2工具的使用|MAC电脑终端实现分屏|iterm2开启滚动操作

iterm2 工具概括 iTerm2 是一款非常强大的终端工具。 iTerm2 最初是为 macOS 开发的,但也有 Windows 、Linux 发行版&#xff08;Ubuntu、centos…&#xff09;可用。 应用场景 Mac操作系统中想实现终端分屏 iterm2 工具特点 多标签和分屏: 可以在同一个窗口中打开多个标签…

leetcode日记(48)排列序列

这道题想到了规律就不算难&#xff0c;列了好几个示例想出的规律&#xff0c;试着排序几个就会了 class Solution { public:string getPermutation(int n, int k) {string result;int m1;int i1;for(i;i<n;i) m*i;i--;int pm/i;string s;for(int j0;j<n;j) s.append(to_…

基于VUE的软件项目开发管理系统/项目管理系统/软件开发过程管理系统的设计与实现

摘 要 在Internet高速发展的今天&#xff0c;我们生活的各个领域都涉及到计算机的应用&#xff0c;其中包括软件项目开发管理系统的网络应用&#xff0c;在外国软件项目开发管理系统已经是很普遍的方式&#xff0c;不过国内的软件项目开发管理可能还处于起步阶段。软件项目开发…

【计算机网络】三次握手、四次挥手

问&#xff1a;三次握手 四次挥手 TCP 连接过程是 3 次握手&#xff0c;终止过程是 4 次挥手 3次握手 第一步&#xff1a;客户端向服务器发送一个带有 SYN&#xff08;同步&#xff09;标志的包&#xff0c;指示客户端要建立连接。 第二步&#xff1a;服务器收到客户端的请求…

QtCreator和QtDesignStudio最佳实践

一、QTC和QDS工作流概述 很多初学者对 QDS(Qt Design Studio) 和 QTC(Qt Creator)如何配合经常存有疑问&#xff0c;本文介绍具体的工作流程。 工作流程 1.产品设计&#xff1a;通过PS、Figma、XD等专业工具设计页面视觉和原型。 2.QDS 原型制作&#xff1a;导入设计源文件、…

react中如何mock数据

1.需求说明 因为前后端分离开发项目&#xff0c;就会存在前端静态页面写好了&#xff0c;后端数据接口还没写好&#xff1b;这时候前端就需要自己定义数据来使用。 定义数据有三种方式&#xff1a;直接写死数据、使用mock软件、json-server工具 这里讲解通过json-server工具…

如何通过一条SQL变更多个分库分表?

数据库发展到今天&#xff0c;分库分表已经不是什么新鲜话题了&#xff0c;传统的单节点数据库架构在数据量和访问频次达到一定规模时&#xff0c;会出现性能瓶颈和扩展性问题&#xff0c;而分库分表技术通过将数据分散到多个数据库实例中来分担负载&#xff0c;从而提升系统的…

Electron的入门介绍与使用(1)共30节

Electron是一个使用 JavaScript、HTML 和 CSS 构建桌面应用程序的框架。 嵌入 Chromium 和 Node.js 到 二进制的 Electron 允许您保持一个 JavaScript 代码代码库并创建 在Windows上运行的跨平台应用 macOS和Linux——不需要本地开发 经验。 入门指南​ Electron 是网页应用 …

IEDA怎么把springboot项目 启动多个

利用Idea提供的Edit Configurations配置应用参数。 点击Modify Options进行添加应用参数&#xff1a; 确保这里勾选

宿舍生活新升级:智能指纹锁的便捷体验(嘉立创EDA设计)

宿舍生活新升级&#xff1a;智能指纹锁的便捷体验 引言 宿舍生活总是充满挑战和乐趣&#xff0c;但有时也会因为一些小事情而变得复杂。比如&#xff0c;忘记带钥匙或者需要频繁地给室友开门。随着科技的发展&#xff0c;智能设备逐渐走进我们的生活&#xff0c;为日常带来便…

每日好题(2)

#define _CRT_SECURE_NO_WARNINGS #include <stdio.h> int main(void) {int arr[6] { 1,2,3,4,5,6 };char* p arr;int sz sizeof(arr) / sizeof(arr[0]);for (int a 0; a < sz; a){printf("%d\n", *p);p 4;}return 0; }这串代码遍历打印数组的结果是没…

在 VM 虚拟机中安装 openEuler + 桌面

在 VM 虚拟机中安装 openEuler 1 介绍2 步骤语言Root 账户安装位置网络和主机名自动检索到【推荐】手动配置网络 软件选择安装完成登录测试网络curl ip / ping ipip link show / ip a如网络不通&#xff0c;可检查网卡状态和dns配置 安装命令设置以图形界面的方式启动【dde】第…

Python Django功能强大的扩展库之channels使用详解

概要 随着实时 web 应用程序的兴起,传统的同步 web 框架已经无法满足高并发和实时通信的需求。Django Channels 是 Django 的一个扩展,旨在将 Django 从一个同步 HTTP 框架转变为一个支持 WebSockets、HTTP2 和其他协议的异步框架。它不仅能够处理传统的 HTTP 请求,还可以处…