我个人总结的优先队列

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
/*
//系统自带比较函数的优先队列 最大值优先
#include<stdio.h>
#include<queue>
using namespace std;
int main()
{
       int a[]={14,10,56,7,83,22,36,91,3,47,72,0};
    priority_queue<int,vector<int>,less<int> >que;//less<int>是比较函数也可以自己写 下面有 que是自己定义的队列名称 随便改
    int i;
    for(i=0;a[i];i++)
    {
     que.push(a[i]);
    }
    while(!que.empty())
    {
     printf("%d\n",que.top());
     que.pop();
    }
    return 0;
   
}
*/
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
/*
//系统自带比较函数的优先队列 最小值优先
#include<stdio.h>
#include<queue>
using namespace std;
int main()
{
       int a[]={14,10,56,7,83,22,36,91,3,47,72,0};
    priority_queue<int,vector<int>,greater<int> >que;//greater<int>是比较函数也可以自己写 下面有 que是自己定义的队列名称 随便改
    int i;
    for(i=0;a[i];i++)
    {
     que.push(a[i]);
    }
    while(!que.empty())
    {
     printf("%d\n",que.top());
     que.pop();
    }
    return 0;
   
}
*/

////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
/*#include<stdio.h>
#include<queue>
using namespace std;
struct haha
{
 bool operator ()(double &a,double &b)
 {
  return a>b;//最小值优先出队
 }
};
int main()
{
    double a[]={14,10,56,7,83,22,36,91,3,47,72,0};
 priority_queue<double,vector<double>,haha>duilie;//haha是自己定义的结构体名字 队列是自己取的队列名字
      int i;
   for(i=0;a[i];i++)
    duilie.push(a[i]);
   while(!duilie.empty())
   {
    printf("%lf\n",duilie.top());
           duilie.pop();
   }
return 0;
}
//改成int也是一样的      如果要改对应把lf换成%d哈
//priority_queue<Type, Container, Functional>中的三个参数 如下
//Type 为数据类型, Container 为保存数据的容器,Functional 为元素比较方式即比较函数
*/
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

/*#include<stdio.h>
#include<queue>
using namespace std;
struct haha
{
 bool operator ()(double &a,double &b)
 {
  return a<b;//最大值优先出队
 }
};
int main()
{
    double a[]={14,10,56,7,83,22,36,91,3,47,72,0};
 priority_queue<double,vector<double>,haha>duilie;//haha是自己定义的结构体名字 队列是自己取的队列名字
      int i;
   for(i=0;a[i];i++)
    duilie.push(a[i]);
   while(!duilie.empty())
   {
    printf("%lf\n",duilie.top());
           duilie.pop();
   }
return 0;
}
//改成int也是一样的      如果要改对应把lf换成%d哈
//priority_queue<Type, Container, Functional>中的三个参数 如下
//Type 为数据类型, Container 为保存数据的容器,Functional 为元素比较方式即比较函数
*/
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
/*
//无自定义函数   默认按大到小
#include<stdio.h>
#include<queue>
using namespace std;//由于该函数没有.h所以必须加上using namespace std 否则报错
int main()
{
 int a[]={14,10,56,7,83,22,36,91,3,47,72,0};
 int i;
    priority_queue<int>que;//que是自己随意定义的队列名字
 for(i=0;a[i];i++)
  que.push(a[i]);//把a[i]入队
 while(!que.empty())//当不是空队的时候
 {
  printf("%3d",que.top());//打印队首元素
  que.pop();//队首元素出队
 }
}
*/
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
 
 
最重要的还是要看结构体中的优先队列  结合实例 详看 日志
BFS之 hdu 1072 nightmare和
BFS之 hdu1242

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值