【C++】优先级队列反向迭代器的实现

news2025/1/22 17:04:10

一、优先级队列:

优先级队列(priority queue)是一种容器适配器,

它默认使用vector作为其底层存储数据的容器,在vector上又使用了堆算法将vector中元素构造成堆的结构,因此priority_queue就是堆,所有需要用到堆的位置,都可以考虑使用priority_queue。

注意:默认情况下priority_queue是大堆。

向上和向下调整

首先:既然是堆就肯定有向上和向下调整,这些在之前学习中就已经学过了:

void AdjustDown(int parent)
{
	int child = parent * 2 + 1;
	while (child < _con.size())
	{
		//先找到子节点的小些的那个
		if (child + 1 < _con.size() && _con[child] < _con[child + 1])
		{
			child++;
		}

		if (_con[parent] < _con[child])
		{ 
			swap(_con[child], _con[parent]);
			parent = child;
			child = parent * 2 + 1;
		}
		else
		{
			break;
		}
	}
}

void AdjustUp(int child)
{
	int parent = (child - 1) / 2;
	while (child > 0)
	{
		if (_con[parent] < _con[child])
		{
			swap(_con[child], _con[parent]);

			child = parent;
			parent = (child - 1) / 2;
		}
		else {
			break;
		}
	}
}

默认构造函数:

首先,在模拟实现中,只有一个成员变量_con,它的类型默认就是vector,一般不会改变的,那么在实现构造函数中,就可以让这个自变量自己去调用它的构造函数。

push:

思路:

将传过来的那个值直接通过容器vector尾插进入,然后在进行向上调整即可。

void push(const T& x)
{
	_con.push_back(x);

	AdjustUp(_con.size() - 1);
}

头删pop:

思路:

首先要知道,是不能够直接删除最开始的位置的,如果删了,那么就会将堆的顺序搞混乱,所以要先将根位置和末位置交换,在进行尾删即可。

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

访问堆顶元素top:

思路:

容器毕竟是vector,那么直接用[] 访问第一个元素即可

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

判断堆顶元素是否为空:

思路同上

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

计算堆的个数有多少:

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

二、仿函数:

1、定义:

仿函数实际上就是让一个类在使用上像一个函数,实现就是重载了运算符(),这样这个类就有了类似于函数的行为,这就是仿函数。

注意:

仿函数是类不是函数,只是重载了()看上去像函数。

2、使用:

在上述向上或者向下的调整中,可以在两个节点中的比较中使用仿函数,

首先定义仿函数:

class Less
{
public:
	bool operator()(const T& x, const T& y)
	{
		return x < y;
	}
};

template<class T>
class Greator
{
public:
	bool operator()(const T& x, const T& y)
	{
		return x > y;
	}
};

接着在priority_queue这个类的模版参数中多加一个模版参数来控制大于还是小于,

template<class T,class Container = vector<T>,class Compare = Less<T>>

这样的话,如果在参数中给less或者不给,就建立大堆,

如果给greater就建立小堆

三、反向迭代器的实现:

在库里面,反向迭代器是封装正向迭代器来实现的,如上图,正向迭代器的begin是反向迭代器的end,正向迭代器的end是反向迭代器的begin

注意:

在实现解引用中,解引用的是当前位置的下一个位置,判断的是正常判断的,如果不是解引用的下一个位置的话,那么就会在rend的数据访问不到。

其余都封装正向迭代器实现

namespace ppr
{
	template<class Iterator,class Ref ,class Ptr>
	struct ReverseIterator
	{
		typedef ReverseIterator<Iterator, Ref, Ptr> Self;
		ReverseIterator(Iterator it)
			:_it(it)
		{}

		Ref operator*()
		{
			Iterator tmp = _it;
			return *(--tmp);
		}

		Ptr operator->()
		{
			return &(operator*());
		}


		Self& operator++()
		{
			--_it;
			return *this;
		}

		Self& operator--()
		{
			++_it;
			return *this;
		}

		bool operator!=(const Self& lt) const
		{
			return _it != lt._it;
		}
		
		bool operator==(const Self& lt) const
		{
			return _it == lt._it;
		}
		
		Iterator _it;
	};
}

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

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

相关文章

Rust 助力无服务器构筑云计算新引擎

引言 今年 Amazon Lambda 迎来了它的第一个十周年。在过去的十年里&#xff0c;无服务器架构改变了软件开发的方式&#xff0c;简化了应用程序的部署和扩展&#xff0c;成为云计算的新引擎。而在众多支持无服务器技术的编程语言中&#xff0c;Rust 以其卓越的安全性和高性能成…

项目管理工作流是什么?项目管理工作流管理实战技巧!

项目管理工作流是指在协作过程中通过限制任务状态的流转进行流程控制的一种方式。项目从启动到完成所经历的一系列有序、可控的步骤和流程&#xff0c;它详细描述了项目执行过程中各项任务和活动的顺序、依赖关系、责任人以及完成标准等&#xff0c;是项目成功执行的重要保障。…

java设计模式 桥接模式

桥接模式&#xff08;Bridge Pattern&#xff09;是一种结构型设计模式&#xff0c;旨在将抽象部分与其实现部分分离&#xff0c;使它们都可以独立地变化。桥接模式通过将继承改为组合&#xff0c;实现了在不修改现有类的情况下&#xff0c;动态地切换和扩展抽象类与其具体实现…

Windows 平台安装 Nacos 2.x

环境准备 64 位操作系统&#xff0c;Windows 10 / Linux Centos 7JDK 1.8 安装包下载 安装包下载官方地址&#xff1a;https://github.com/alibaba/nacos/releases 启动 将安装包解压到安装的目录下&#xff0c;改名为 nacos-2.0.4。然后进行到 bin 目录下&#xff0c;打开…

数据集 Look into Person (LIP) 是最流行的单人人体语义分割 >> DataBall

开源数据集 Look into Person (LIP) 是最流行的单人人体语义分割 深度学习 Look into Person (LIP) 是最流行的单人人体分割数据集&#xff0c;它使用像素级注释进行注释&#xff0c;具有19个语义人体部分标签和一个背景标签。LIP包含50,462个带注释的图像&#xff0c;分为30,4…

CAN集线器(工业级、隔离式)

型号&#xff1a; MS-HUB-C 概述 MS-HUB 是一款可通过一路 CAN &#xff0c;一路 RS-232为主口扩展出 7 路 CAN 从口的工业级光电隔离型 CAN 分配器。可以有效的实现 CAN 网络的中继、扩展与隔离。采用先进的自动流控技术自动侦测CAN 信号流向。MS-HUB 具备光电隔离功能&#x…

UEFI学习笔记(二):edk2构建编译流程

UEFI入门&#xff08;二&#xff09;&#xff1a;edk2项目编译流程 一、Build流程框架Build的三个阶段&#xff1a;1、Autogen2、Make3、ImageGen 二、编译构建步骤&#xff1a;1. 安装依赖工具2. 初始化构建环境3. 配置工具链和目标4. 定义平台配置5. 构建并编译 三、uefi-too…

怎么通过Java实现和数据库的连接???(附带练习)

JDBC 今日目标 掌握JDBC的的CRUD理解JDBC中各个对象的作用掌握Druid的使用 1&#xff0c;JDBC概述 在开发中我们使用的是java语言&#xff0c;那么势必要通过java语言操作数据库中的数据。这就是接下来要学习的JDBC。 1.1 JDBC概念 JDBC 就是使用Java语言操作关系型数据库的…

STL-stack/queue/deque(容器适配器)

目录 ​编辑 STL-stack 150. 逆波兰表达式求值 stack queue std::stack deque 性能测试 结构 STL-stack 栈的压入、弹出序列_牛客题霸_牛客网输入两个整数序列&#xff0c;第一个序列表示栈的压入顺序&#xff0c;请判断第二个序列是否可能为该栈的弹出顺序。假。题目…

TESSY创建以及设计一个测试用例

我们以tessy5.1 IDE为例&#xff0c;给大家展示编写一个测试用例的过程。 还不会创建工程的&#xff0c;可以参考以下这篇文章&#xff1a; TESSY创建单元测试或集成测试工程_tessy 集成测试-CSDN博客 接下来我们以这个作为开始状态进行介绍 1、添加源文件 2、添加头文件路径…

存储型XSS漏洞

1.介绍 存储型XSS攻击是一种常见的网络攻击&#xff0c;也称为持久型XSS攻击。与反射型XSS攻击不同&#xff0c;存储型XSS攻击将恶意代码存储在服务器端或数据库中&#xff0c;当其他用户访问该网页时&#xff0c;恶意代码会被执行&#xff0c;导致用户的信息被窃取或造成其他…

Redis相关命令详解

目录 一、认识Redis 二、string 1、重要知识 2、基础命令 3、Key值的设置 三、list 1、重要知识 2、存储结构 3、基础命令 4、list的应用场景 四、hash 1、重要知识 2、基础命令 五、set 1、重要知识 2、基础命令 3、具体应用 六、zset 1、重要知识 2、…

“禁塑行动·我先行”广州绿葆网络发展有限公司与辽宁省慈善联合总会共谱环保新篇章

2024年9月9日&#xff0c;在国家大力推进生态文明建设、全面实施禁塑令政策的大背景下&#xff0c;农工同心公益基金“禁塑行动我先行”公益捐赠辽宁省启动仪式在辽宁省成功举办。此次活动由辽宁省慈善联合总会、农工党辽宁省委会主办&#xff0c;辽宁省慈善联合总会农工同心公…

MUR2060CT-ASEMI快恢复二极管MUR2060CT

编辑&#xff1a;ll MUR2060CT-ASEMI快恢复二极管MUR2060CT 型号&#xff1a;MUR2060CT 品牌&#xff1a;ASEMI 封装&#xff1a;TO-220AB 安装方式&#xff1a;插件 批号&#xff1a;最新 恢复时间&#xff1a;35ns 最大平均正向电流&#xff08;IF&#xff09;&#…

噪声的消除

开关电源的干扰一般是几十K到几百K&#xff1a; 【电源噪声查不出来&#xff1f;不用上板子&#xff0c;滤波器仿真就能搞定】https://www.bilibili.com/video/BV12v411r798?vd_source3cc3c07b09206097d0d8b0aefdf07958 村田消除噪声的仿真软件&#xff1a; SimSurfing - 村…

Kafka原理剖析之「Topic创建」

一、前言 Kafka提供了高性能的读写&#xff0c;而这些读写操作均是操作在Topic上的&#xff0c;Topic的创建就尤为关键&#xff0c;其中涉及分区分配策略、状态流转等&#xff0c;而Topic的新建语句非常简单 bash kafka-topics.sh \ --bootstrap-server localhost:9092 \ // …

QT设置闹钟超时播报

头文件 #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include<QTimerEvent> #include<QTime> #include<QTextToSpeech>QT_BEGIN_NAMESPACE namespace Ui { class Widget; } QT_END_NAMESPACEclass Widget : public QWidget {Q_OBJECTpublic…

mysql 之 information_schema

information_schema 是 MySQL 中的一个特殊数据库&#xff0c;它提供了关于 MySQL 服务器中所有数据库、表、列、索引、存储过程、函数、触发器等对象的元数据信息。information_schema 是一个只读数据库&#xff0c;主要用于查询数据库的结构信息&#xff0c;而不是存储用户数…

【Unity踩坑】创建新项目后提示编译错误要进入安全模式

在创建了新项目后&#xff08;比如URP&#xff0c;AR&#xff0c;VR&#xff09;&#xff0c;首次打开时提示有编译错误&#xff0c;要进入安全模式。 脚本是项目模板自带的&#xff0c;不会有问题。这时需要先选择进入安全模式&#xff0c;然后关闭项目&#xff0c;重新打开就…

C++之函数进阶

函数默认参数 注意事项&#xff1a; 1. 如果从某个位置开始&#xff0c;有了默认参数&#xff0c;那么从这个位置往后&#xff0c;都必须有默认参数 2. 函数声明和函数定义只能有一个进行默认参数设置 函数占位参数 函数重载 函数名相同void fun()&#xff0c;功能实现不同 提高…