【STL】优先级队列用法介绍及其实现

目录

前言

用法介绍

模拟实现

仿函数

迭代器区间构造 

插入

删除

队顶

判空

大小

完整代码


前言

优先级队列(priority_queue)是一种特殊的队列数据结构,其中每个元素都有一个“优先级”。优先级最高的元素最先出队,而优先级最低的元素则最后出队。元素优先级的高低通常由它的值决定。

用法介绍

//传迭代器区间构造
template <class InputIterator>
priority_queue (InputIterator first, InputIterator last,const Compare& comp = Compare(),
const Container& ctnr = Container());//插入
void push(const value_type& val);//弹出队头
void pop();//返回队头元素但不删除
const_reference top() const;//队列中的数据个数
size_type size() const;//判断队列是否为空
bool empty() const;

 其中,上述构造函数的第三个参数为仿函数,在下面的实现中将会介绍。

模拟实现

底层用vector实现。

仿函数

仿函数其实是一个重载了operator()的类,使得该类的对象在调用operator()是看起来像函数调用一样。

struct less
{bool operator()(int x, int y){return x < y;}
};int main()
{less cmp;cmp(1, 2);//像函数一样调用return 0;
}

迭代器区间构造 

1)将该区间内的所有元素插入vector中

2)向下调整建堆

代码:

template<class InputIterator>
priority_queue(InputIterator first, InputIterator last)
{while (first != last){_con.push_back(*first);++first;}for (int i = (_con.size() - 2) / 2; i >= 0; i--){AdjustDown(i);}
}

插入

1)复用底层vector插入数据

2)向上调整

代码:

void push(const T& x)
{_con.push_back(x);AdjustUp(_con.size() - 1);
}

删除

1)堆顶元素与最后一个元素交换

2)复用底层vector的尾删

3)从堆顶开始向下调整

代码:

void pop()
{swap(_con[0], _con[_con.size() - 1]);_con.pop_back();AdjustDown(0);
}

队顶

直接返回vector的头即可。

代码:

const T& top()
{return _con[0];
}

判空

vector为空,则优先级队列为空。

代码:

bool empty()
{return _con.empty();
}

大小

vector的size就是优先级队列的size。

代码:

size_t size()
{return _con.size();
}

完整代码

#include <vector>
#include <iostream>
using namespace std;namespace pcz
{//仿函数template<class T>struct less{bool operator()(const T& x, const T& y){return x < y;}};template<class T>struct greater{bool operator()(const T& x, const T& y){return x > y;}};template<class T, class Container = vector<T>, class Compare = less<T>>class priority_queue{public:priority_queue() : _con() { }template<class InputIterator>priority_queue(InputIterator first, InputIterator last){while (first != last){_con.push_back(*first);++first;}for (int i = (_con.size() - 2) / 2; i >= 0; i--){AdjustDown(i);}}void push(const T& x){_con.push_back(x);AdjustUp(_con.size() - 1);}void pop(){swap(_con[0], _con[_con.size() - 1]);_con.pop_back();AdjustDown(0);}const T& top(){return _con[0];}size_t size(){return _con.size();}bool empty(){return _con.empty();}void AdjustUp(int child){int parent = (child - 1) / 2;while (child > 0){//仿函数if (comp(_con[parent], _con[child])){swap(_con[parent], _con[child]);child = parent;parent = (child - 1) / 2;}else{break;}}}void AdjustDown(int parent){int child = parent * 2 + 1;while (child < _con.size()){//仿函数if (child + 1 < _con.size() && comp(_con[child], _con[child + 1]))child++;if (comp(_con[parent], _con[child])){swap(_con[parent], _con[child]);parent = child;child = parent * 2 + 1;}else{break;}}}protected:Container _con;//底层容器Compare comp;  //元素大小比较标准};
}#include "priority_queue.h"int main()
{int a[] = { 0,1,2,3,4,8,9,3,5 };pcz::priority_queue<int> q(a, a + 9);while (!q.empty()){cout << q.top() << " ";q.pop();}cout << endl;return 0;
}

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

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

相关文章

内网域中NTLM中继那些事儿

0x01 初识NTLM协议 基本概念&#xff1a;NTLM(NT LAN Manager)认证是一种早期的Windows网络身份认证协议。它在Windows系统中用于验证用户的身份&#xff0c;并提供对网络资源的访问控制&#xff0c;它是一种基于Challenge/Response的认证机制。 认证流程 NTLM协议Challenge…

Python代码关系图生成,帮助快速熟悉一个项目

一、静态代码关系图 工具1、pyreverse pyreverse 是一个由 Logilab 开发的 Python 工具&#xff0c;它能够自动生成 UML (统一建模语言) 类图&#xff0c;这些类图基于 Python 源代码。pyreverse 可以分析 Python 代码&#xff0c;并从中提取出类、模块、函数、方法和它们之间…

电脑世界的大冒险:用人体比喻让孩子轻松理解电脑20240603

电脑世界的大冒险&#xff1a;用人体比喻让孩子轻松理解电脑 作为一名在IT行业的老程序猿&#xff0c;我见证了电脑技术的飞速发展&#xff0c;也亲身体验了科技给生活带来的翻天覆地的变化。然而&#xff0c;在这个日新月异的数字时代&#xff0c;我意识到&#xff0c;与孩子…

调用大模型API 给产业分类

文章目录 大模型API 给产业分类简要描述大模型API Tips联系方式 大模型API 给产业分类 简要描述 从全国几亿条企业工商登记数据中&#xff0c;抽取出与氢能领域的企业&#xff1b; 根据关键词匹配&#xff0c;看企业的名称和经营范围中&#xff0c;是否包含“氢”&#xff0…

Window下VS2019编译WebRTC通关版

这段时间需要实现这样一个功能&#xff0c;使用WebRTC实现语音通话功能&#xff0c;第一步要做的事情就是编译WebRTC源码&#xff0c;也是很多码友会遇到的问题。 经过我很多天的踩坑终于踩出来一条通往胜利的大路&#xff0c;下面就为大家详细介绍&#xff0c;编译步骤以及踩…

gradle wrapper properties下载gradle的换下载地址方案

修改gradle-wrapper.properties文件 #Mon Jun 03 01:40:29 CST 2024 distributionBaseGRADLE_USER_HOME distributionPathwrapper/dists # 比如说源地址是默认的,这里改为腾讯云的, 也可以其他镜像地址 distributionUrlhttps\://mirrors.cloud.tencent.com/gradle/gradle-8.6-…

安卓组合控件(底部标签栏、顶部导航栏、增强型列表、升级版翻页)

本章介绍App开发常用的一些组合控件用法&#xff0c;主要包括&#xff1a;如何实现底部标签栏、如何运用顶部导航栏、如何利用循环视图实现3种增强型列表、如何使用二代翻页视图实现更炫的翻页效果。 底部标签栏 本节介绍底部标签栏的两种实现方式&#xff1a;首先说明如何通…

初识SDN(二)

初识SDN&#xff08;二&#xff09; SDN部分实现 REST API 是什么&#xff1f; REST API&#xff08;Representational State Transfer Application Programming Interface&#xff0c;表述性状态传递应用程序接口&#xff09;是一种基于HTTP协议的接口&#xff0c;广泛用于…

minos 2.3 中断虚拟化——GICv2 管理

首发公号&#xff1a;Rand_cs 该项目来自乐敏大佬&#xff1a;https://github.com/minosproject/minos 硬件肯定需要软件配合&#xff0c;这一节就来实战 GICv2 首先准备好 GICv2 手册&#xff1a;https://developer.arm.com/documentation/ihi0048/bb/?langen&#xff0c;对…

vue3 vue-draggable-next 实现拖拽穿梭框效果

一、vue3 vue-draggable-next 实现拖拽穿梭框效果 <template> <div> <h2>列表 1</h2> <draggable v-model"list1" group"items" tag"transition-group" end"onDragEnd"> <div v-for"(item…

java中的抽象类与抽象方法

在Java中&#xff0c;抽象类和抽象方法是非常重要的概念&#xff0c;它们与面向对象编程中的多态性和继承紧密相关。以下是对Java中抽象类和抽象方法的详细介绍&#xff1a; 1. 抽象类&#xff08;Abstract Class&#xff09; 定义&#xff1a; 抽象类是一个不能被实例化的类…

C++面试题其三

继续解答常见的C面试题 继续上篇博客的解答&#xff0c;我们将进一步探讨C中的一些关键概念和常见面试问题。 29. typedef和define的区别 typedef&#xff1a;用于为现有类型定义一个新的名字。typedef是编译时的操作&#xff0c;它提供了类型别名&#xff0c;可以提高代码可…

深入剖析Java逻辑运算符,解决日常开发难题

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。运营社区&#xff1a;C站/掘金/腾讯云&#xff1b;欢迎大家常来逛逛 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一…

达梦数据库的锁介绍

达梦数据库的锁介绍 达梦数据库&#xff08;DM Database&#xff09;是一款国产数据库管理系统&#xff0c;它支持多种类型的锁机制&#xff0c;用于控制并发访问&#xff0c;确保数据一致性和完整性。锁的使用是数据库并发控制中的一个重要方面&#xff0c;可以通过合理的锁机…

SpringBoot:手动创建应用

Spring提供了在线的Spring Initialzr在线创建Spring Boot项目&#xff0c;为了更好的理解Spring Boot项目&#xff0c;这里我们选择手动创建。 1.新建Web应用 1.1 生成工程 首先要做是创建一个Java项目&#xff0c;这里我们选择使用Maven来支持&#xff0c;使用archetype:ge…

现成方案 - 复刻版类似 Perplexity 与秘塔 AI 的搜索引擎

这里为大家带来一个极具创新性的开源 AI 搜索引擎&#xff0c;其灵感源自 Perplexity。 该搜索引擎主要具备以下功能&#xff1a; 能够接收用户提出的各种问题。借助 Bing 搜索 API 可查找出前 6 个结果并予以展示。会抓取这 6 个链接的文本内容&#xff0c;将其作为重要的上下…

MATLAB算法实战应用案例精讲-【数模应用】Turf组合模型(附MATLAB、python和R语言代码实现)

目录 几个高频面试题目 如何以最小的成本覆盖到最大的消费群体? 应用场景 TURF举例

如何在 Ubuntu VPS 上部署 Flask 应用程序

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。 什么是高亮显示 在本教程中,用户需要输入或自定义的行将以高亮显示!其余部分应大多可以复制并粘贴。 介绍 Flask 是一个用 Python 编写的微框架,基于 Werkzeug 和…

Gavin Wood 访谈|Polkadot 从何而来,又将如何面对 AI 时代?

如果没有宏观经济&#xff0c;加密世界可能无法存在。或许&#xff0c;Satoshi Nakamoto 也永远不会写出那篇开创性的白皮书。区块链技术作为指数时代的核心之一&#xff0c;在宏观经济理论中占有重要地位。传统的经济增长公式是人口增长加生产率增长加债务增长。然而&#xff…

Python 高级数据类型

列表List 定义列表 可以将不同的基本数据类型或者列表装到一个列表里 my_list [1,2,3,4,5] print(my_list) # [1, 2, 3, 4, 5] 直接打印出列表的内容 print(type(my_list)) # <class list>my_list ["1","2","3","4","…