c++ queue队列与优先队列

c++ set用法详解
c++ stack用法详解
c++几种重载

queue

队列是基本的数据结构之一,特点是"先进先出",如我们的日常排队

queue常用操作

在c++ 中,queue的头文件是#include<queue>

queue<int> q;   //以int型为例
int x;
q.push(x);		//将x放入队列
q.front();	 	//返回队首元素
q.pop();		//删除队首元素
q.back();		//返回队尾元素
q.size();		//返回q中的元素个数
q.empty();		//检查队列是否为空,若为空返回true,否则返回false

普通队列

#include<iostream>
#include<queue>
using namespace std;
int main()
{
	queue<int> q;
	q.push(1);
	q.push(2);
	q.push(3);
	q.push(4);
	q.push(5);
	
	cout<<"q.size "<<q.size()<<endl;
	cout<<"q.front "<<q.front()<<endl;  //返回队首元素 
	cout<<"q.back "<<q.back()<<endl;	//返回队尾元素
	
	q.pop();	//删除队首元素
	cout<<"q.size "<<q.size()<<endl;
	cout<<"q.front "<<q.front()<<endl;  //返回队首元素 	 
	
	return 0;
}

对于普通队列的结构体排序,建议阅读 c++几种重载

单元素的优先队列priority_queue<int>

#include<iostream>
#include<queue>
using namespace std;
int main()
{
	priority_queue<int> a;  //默认大到小
	priority_queue<int,vector<int>,greater<int> > b;  //小到大
 
	a.push(3);
	a.push(2);
	a.push(1);
	a.push(9);
	b.push(3);
	b.push(2);
	b.push(1);
	b.push(9);
	while(!a.empty())
	{
		cout<<a.top()<<" ";
		a.pop();
	}
	cout<<endl;
	while(!b.empty())
	{
		cout<<b.top()<<" ";
		b.pop();
	}
	return 0;
}   

多元素的优先队列(结构体)

#include<iostream> 
#include<algorithm>
#include<queue>
using namespace std;
struct node  
{
	int x,y;
	bool operator < (const node &a) const
	{
		return x<a.x;   //按x的值降序序排列 
	}
}t;

int main()
{

	priority_queue<node> q;
	t.x=3;
	t.y=2;
	q.push(t);
	
	t.x=4;
	t.y=6;
	q.push(t);
	
	t.x=1;
	t.y=2;
	q.push(t);
	
	while(q.size())
	{
		t=q.top();
		q.pop();
		cout<<t.x<<" "<<t.y<<endl;
	}
	
	return 0;
} 


c++ set用法详解
c++ stack用法详解
c++几种重载

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值