优先队列

优先队列

  • 优先队列容器与队列一样,只能从队尾插入元素,从队首删除元素。但是它有一个特性,就是队列中最大的元素总是位于队首,所以出队时,并非按照先进先出的原则进行,而是将当前队列中最大的元素出队。这点类似于给队列里的元素进行了由大到小的顺序排序。元素的比较规则默认按元素值由大到小排序,可以重载“<”操作符来重新定义比较规则。

  • priority_queue<vector, less > pq1;     // 使用递增less函数对象排序
    priority_queue<deque, greater > pq2;   // 使用递减greater函数对象排序

基本操作功能
pop()删除对顶元素,删除第一个元素
empty()如果队列为空,则返回真
push()加入一个元素
size()返回优先队列中拥有的元素个数
top()返回优先队列对顶元素,返回优先队列中有最高优先级的元素
  • 声明方法
    1、普通方法:
    priority_queue q;   //通过操作,按照元素从大到小的顺序出队
    priority_queue<int,vector, greater > q;   //通过操作,按照元素从小到大的顺序出队

    2、自定义优先级:

struct cmp {     
  operator bool ()(int x, int y)     
  {        
     return x > y;   // x小的优先级高       
     //也可以写成其他方式,如: return p[x] > p[y];表示p[i]小的优先级高
  }
};
priority_queue<int, vector<int>, cmp> q;    //定义方法
//其中,第二个参数为容器类型。第三个参数为比较函数。

3、结构体声明方式:

struct node {     
  int x, y;     
  friend bool operator < (node a, node b)     
  {         
    return a.x > b.x;    //结构体中,x小的优先级高     
  }
};
priority_queue<node>q;   //定义方法
//在该结构中,y为值, x为优先级。
//通过自定义operator<操作符来比较元素中的优先级。
//在重载”<”时,最好不要重载”>”,可能会发生编译错误

eg蓝桥杯第九届第四题

标题:第几个幸运数 到x星球旅行的游客都被发给一个整数,作为游客编号。 x星的国王有个怪癖,他只喜欢数字3,5和7。
国王规定,游客的编号如果只含有因子:3,5,7,就可以获得一份奖品。 我们来看前10个幸运数字是: 3 5 7 9 15 21 25 27
35 45 因而第11个幸运数字是:49 小明领到了一个幸运数字
59084709587505,他去领奖的时候,人家要求他准确地说出这是第几个幸运数字,否则领不到奖品。
请你帮小明计算一下,59084709587505是第几个幸运数字。 需要提交的是一个整数,请不要填写任何多余内容。

#include <bits/stdc++.h>//9-4幸运数 
using namespace std;
const int a[]={3,5,7}; 
const long long maxn= 59084709587505;
priority_queue<long long,vector<long long>,greater<long long> >p;
set<long long>s;
int res;
int main()
{
	long long m,n;
	for(int i=0;i<3;i++) p.push(a[i]);
	while((n=p.top())<=maxn) 
	{
		p.pop();
		res++;
		for(int i=0;i<3;i++)
		{
			m=n*a[i];
			if(!s.count(m))
			{
				s.insert(m);
				p.push(m);
			}
		}
	}
	cout<<res;
	return 0;
 } 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值