【C++】priority_queue的用法(模板参数的实例)

2024-06-13 15:20

本文主要是介绍【C++】priority_queue的用法(模板参数的实例),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【C++】priority_queue的用法

文章目录

  • 【C++】priority_queue的用法
    • 大根堆
    • 小根堆
    • 自定义类型优先级队列

使用priority_queue需要包含头文件 <queue>
其模板申明带3个参数:priority_queue<Type, Container, Functional>,其中Type 为数据类型,Container为保存数据的容器,Functional 为元素比较方式。
其中Container必须是使用数组实现的容器,例如vector、dequeue等,不能使用list。

大根堆

该函数使用,后两个参数可以缺省,例如可以声明这样一个优先级队列:priority_queue<int> q,此时元素的比较方式默认用operator<,优先级队列就是大根堆,队头元素最大。

#include<iostream>
#include<vector>
#include<queue>
using namespace std;
int main(){priority_queue<pair<int,int> > coll;pair<int,int> a(3,4);pair<int,int> b(3,5);pair<int,int> c(4,3);coll.push(c);coll.push(b);coll.push(a);while(!coll.empty()){cout<<coll.top().first<<"\t"<<coll.top().second<<endl;coll.pop();}return 0;
}//-------------------------------------
//来源于https://www.cnblogs.com/shona/p/12163381.html

小根堆

如果要实现小根堆,则需要把模板的3个参数都填写清除。STL里面定义了一个仿函数greater<>,基本类型可以用这个仿函数声明小顶堆。以下代代码返回pair的比较结果,先按照pair的first元素升序,first元素相等时,再按照second元素升序:

#include<iostream>
#include<vector>
#include<queue>
using namespace std;
int main(){priority_queue<pair<int,int>,vector<pair<int,int> >,greater<pair<int,int> > > coll;pair<int,int> a(3,4);pair<int,int> b(3,5);pair<int,int> c(4,3);coll.push(c);coll.push(b);coll.push(a);while(!coll.empty()){cout<<coll.top().first<<"\t"<<coll.top().second<<endl;coll.pop();}return 0;
}
//------------------------------------------------------------
//来源于https://www.cnblogs.com/shona/p/12163381.html

自定义类型优先级队列

对于自定义类型优先级队列,则必须重载operator<函数。
例如,我们希望使用优先级队列实现A* 算法 priority_queue;

优先级队列的结构为(open list):

std::priority_queue<std::pair<double, Node>, std::vector<std::pair<double, Node>>, greater> frontier;    // 创建为小根堆 open list

由于我们需要实现一个小根堆,所以三个参数都需要表明,模板中第一个参数表明单个元素的构成:std::pair<double, Node>,单个元素是有一个double数据和一个Node数据共同组成的,第二个参数表明优先级队列的存储容器构成std::vector<std::pair<double, Node>>,使用了一个vector来存储单个元素,第三个参数表明元素的比较方式。

struct greater{  constexpr bool operator() (const std::pair<double, Node>& lhs, const std::pair<double, Node>& rhs) const{//默认是less函数  //返回true时,lhs的优先级低于rhs的优先级(lhs排在rhs的后面)  return lhs.first > rhs.first;  }  
};

Node结构体构成:

struct Node{int x, y;Node( int a= 0, int b= 0 ):x(a), y(b) {}
};

通过这个方式,我们实现了一个优先级队列的A* 算法中的open list。

这篇关于【C++】priority_queue的用法(模板参数的实例)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1057674

相关文章

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

springboot security验证码的登录实例

《springbootsecurity验证码的登录实例》:本文主要介绍springbootsecurity验证码的登录实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录前言代码示例引入依赖定义验证码生成器定义获取验证码及认证接口测试获取验证码登录总结前言在spring

java之Objects.nonNull用法代码解读

《java之Objects.nonNull用法代码解读》:本文主要介绍java之Objects.nonNull用法代码,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录Java之Objects.nonwww.chinasem.cnNull用法代码Objects.nonN

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

JavaScript Array.from及其相关用法详解(示例演示)

《JavaScriptArray.from及其相关用法详解(示例演示)》Array.from方法是ES6引入的一个静态方法,用于从类数组对象或可迭代对象创建一个新的数组实例,本文将详细介绍Array... 目录一、Array.from 方法概述1. 方法介绍2. 示例演示二、结合实际场景的使用1. 初始化二

一文带你了解SpringBoot中启动参数的各种用法

《一文带你了解SpringBoot中启动参数的各种用法》在使用SpringBoot开发应用时,我们通常需要根据不同的环境或特定需求调整启动参数,那么,SpringBoot提供了哪些方式来配置这些启动参... 目录一、启动参数的常见传递方式二、通过命令行参数传递启动参数三、使用 application.pro

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注