C++:优先队列Queue

本文深入讲解了优先队列(queue)的使用方法,包括基本操作如入队、出队、访问队首和队尾元素等。并通过示例展示了如何利用结构体和自定义比较函数来实现复杂的数据处理需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

优先队列Queue

  • queue 模板类的定义在<queue>头文件中
  • queue 的基本操作有:

   1.入队,如例:q.push(x); 将x 接到队列的末端。
   2.出队,如例:q.pop(); 弹出队列的第一个元素,注意,并不会返回被弹出元素的值。
   3.访问队首元素,如例:q.front(),即最早被压入队列的元素。
   4.访问队尾元素,如例:q.back(),即最后被压入队列的元素。
   5.判断队列空,如例:q.empty(),当队列空时,返回true。
   6.访问队列中的元素个数,如例:q.size()

#include<iostream>
#include<functional>
#include<vector>
#include<queue>
using namespace std;

//用法1:数值类型
//operator()(int &a, int &b):操作符重载函数,对含有括号两边的元素进行计算,返回比较的结果
struct cmp1{
	bool operator()(int &a, int &b){
		return a < b;//最大值优先
	}
};


//用法2:结构体类型
struct node1{
	int x, y;
	node1(){}
	node1(int _x, int _y)//为方便赋值,采用构造函数
	{
		x = _x;
		y = _y;
	};
	bool operator<(const node1 &a) const{
		return x < a.x;//按成员X的最大值优先
	}
};

//用法3:结构体类型
struct node2{
	int x, y;
	node2(){}
	node2(int _x, int _y)
	{
		x = _x;
		y = _y;
	};

};
bool operator<(const node2 &a, const node2 &b)
{
	return a.x < b.x;
}

int a[] = { 15, 7, 32, 26, 99, 47, 36, 5,0 };
int b[] = { 1, 2, 6, 8, 7, 23, 17 };

int main()
{
	priority_queue<int>que;
	priority_queue<int, vector<int>, less<int> >que1;

	priority_queue<int, vector<int>, cmp1>que2;
	priority_queue<node1>que3;
	priority_queue<node2>que4;

	int i;
	for (i = 0; a[i]; i++)//截止for条件在于a[i]不等于i初始值或无内部数据NULL
	{
		que.push(a[i]);
		que1.push(a[i]);
		que2.push(a[i]);
	}
	for (i = 0; a[i] && b[i]; i++)
	{
		que3.push(node1(a[i], b[i]));
		que4.push(node2(a[i], b[i]));
	}

	cout << "采用默认优先级 Queue 0:" << endl;
	while (!que.empty()){
		cout << que.top() << " ";
		que.pop();
	}
	cout << endl << endl;

	cout << "采用头文件functional.h内定义优先级Queue 1:" << endl;
	while (!que1.empty()){
		cout << que1.top() << " ";
		que1.pop();
	}
	cout << endl << endl;

	cout << "采用自定义优先级Queue 2:" << endl;
	while (!que2.empty()){
		cout << que2.top() << " ";
		que2.pop();
	}
	cout << endl << endl;

	cout << "采用自定义结构体模式Queue 3:" << endl;
	while (!que3.empty())
	{
		cout << que3.top().x << " ";
		que3.pop();
	}
	cout << endl << endl;

	cout << "采用自定义结构体模式Queue 4:" << endl;
	while (!que4.empty())
	{
		cout << que4.top().x << " ";
		que4.pop();
	}
	cout << endl << endl;
}

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值