IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 模拟实现C++中priority_queue -> 正文阅读

[数据结构与算法]模拟实现C++中priority_queue

priority_queue的介绍

优先级队列默认使用vector作为其底层存储数据的容器,在vector上又使用了堆算法将vector中元素构造成
堆的结构
,因此priority_queue就是堆,所有需要用到堆的位置,都可以考虑使用priority_queue。注意:
默认情况下priority_queue是大堆


函数接口接口说明
priority_queue()/priority_queue(first,last)构造一个空的优先级队列
empty( )检测优先级队列是否为空,是返回true,否则返回
top( )返回优先级队列中最大(最小元素),即堆顶元素
push(x)在优先级队列中插入元素x
pop()删除优先级队列中最大(最小)元素,即堆顶元素

构造函数的基础使用

#include <vector>
#include <queue>
#include <functional> // greater算法的头文件
void TestPriorityQueue()
{
	// 默认情况下,创建的是大堆,其底层按照小于号比较
	vector<int> v{3,2,7,6,0,4,1,9,8,5};
	priority_queue<int> q1;
	for (auto& e : v){
			q1.push(e);
	}	
	cout << q1.top() << endl; 
	cout << q1.top() << endl;
	// 如果要创建小堆,将第三个模板参数换成greater比较方式
	priority_queue<int, vector<int>, greater<int>> q2(v.begin(), v.end());
	cout << q2.top() << endl;
}

如果在priority_queue中放自定义类型的数据,用户需要在自定义类型中提供> 或者< 的重载。


priority_queue的模拟实现

#pragma once
#include<vector>
#include<assert.h>
//使用优先级队列得注意:如果存放的是自定义类型得数据,这个类型得自己重载自己得> 和 < 的函数
namespace xjh{
	template<class T> //仿函数,它是一个类型,可以传给函数模板做参数
	struct Less{
		bool operator()(const T& x, const T& y)const{
			return x < y;
		}
	};
	template<class T> //仿函数,它是一个类型,可以传给函数模板做参数
	struct Greater{
		bool operator()(const T& x, const T& y)const {
			return x > y;
		}
	};
	template<class T,class Container = std::vector<T>,class Compare = Less<T>>
	class priority_queue
	{
	public:
		priority_queue(){}
		template<class InPutIterator>
		priority_queue(InPutIterator first, InPutIterator last)
			:_Con(first,last) //显示调用_Con的默认构造函数
		{
			//建堆
			for (int i = (_Con.size() - 1 - 1) / 2; i >= 0; i--){
				adJustDown(i);
			}
		}
	private:
		//调整前提,堆还是堆,其实用来对插入堆最后一个元素进行调整,搞出来的向上调整算法
		void adJustUp(size_t child){
			size_t parent = (child-1)/2;
			Compare com; 
			while (child > 0){
				//if (_Con[child] > _Con[parent]){
				if (com(_Con[parent], _Con[ child])){
					std::swap(_Con[child], _Con[parent]);
					child = parent;
					parent = (child - 1) / 2;
				}
				else{
					break;
				}
			}
		}
		//向下调整算法,为的是用来建堆使用的
		void adJustDown(size_t parent){
			size_t child = 2 * parent + 1;
			Compare com;
			while (child <_Con.size()){
				//if (child+1<_Con.size() && _Con[child + 1] > _Con[child]){
				if (child + 1<_Con.size() && com(_Con[child], _Con[child+1])){
					child++;
				}
				//if (_Con[child] > _Con[parent]){
				if (com(_Con[parent], _Con[ child])){
					std::swap(_Con[child], _Con[parent]);
					parent = child;
					child = 2 * parent + 1;
				}
				else{
					break;
				}
			}
		}		
	public:
		void push(const T& x){
			_Con.push_back(x);
			adJustUp(_Con.size() - 1);
		}
		void pop(){
			//assert(!_Con.empty());
			//交换堆顶和堆尾
			std::swap(_Con[0], _Con[_Con.size() - 1]);
			//删除堆尾相当于删除堆顶
			_Con.pop_back();
			//再对堆顶进行向下调整
			adJustDown(0);
		}
		const T& top() const{
			return _Con[0];
		}
		size_t size()const{
			return _Con.size();
		}
		bool empty() const {
			return _Con.empty();
		}
	private:
		Container _Con;
	};
}


测试接口代码

#include<iostream>
#include<vector>
#include"priority_queue.h"
using namespace xjh;

int main(){

	priority_queue<int,std::vector<int>,Greater<int>> q;
	q.push(1);
	q.push(12);
	q.push(9);
	q.push(19);
	q.push(3);

	while (!q.empty()){
		std::cout << q.top() << " ";
		q.pop();
	}
	return 0;
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 00:19:45  更:2022-04-01 00:19:58 
 
开发: 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/9 1:40:00-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码