C++ - "priority_queue" 优先级队列 简介 及 代码

时间:2023-02-01 20:46:48

"priority_queue" 优先级队列 简介 及 代码

 

1. 简介

标准库队列使用了先进先出(FIFO)的存储和检索策略. 进入队列的对象被放置在尾部, 下一个被取出的元素则取自队列的首部. 标准库提供了两种风格的队列: FIFO 队列(FIFO queue, 简称 queue), 以及优先级队列(priority queue).

priority_queue 允许用户为队列中存储的元素设置优先级. 这种队列不是直接将新元素放置在队列尾部, 而是放在比它优先级低的元素前面. 标准库默认使用元素类型的 "<" 操作符来确定它们之间的优先级关系. 如需改变大小关系, 需要使用std::greater<temple>函数, 在functional头文件中.

 

2. 代码

#include <iostream>       // std::cout  #include <queue>          // std::priority_queue  #include <vector>          // std::vector  #include <functional>    // std::greater    int main ()  {  int myints[]= {10,60,50,20};    std::priority_queue<int> intPQueue1 (myints, myints+4);  std::priority_queue<int, std::vector<int>, std::greater<int> >  intPQueue2 (myints,myints+4);    std::cout << "less than: " << std::endl;  while( !intPQueue1.empty() ){  int pvalue = intPQueue1.top();  std::cout << pvalue << " ";  intPQueue1.pop();   }  std::cout << std::endl;    std::cout << "bigger than: " << std::endl;  while( !intPQueue2.empty() ){  int pvalue = intPQueue2.top();  std::cout << pvalue << " ";  intPQueue2.pop();   }  std::cout << std::endl;    return 0;  }


 

C++ - "priority_queue" 优先级队列 简介 及 代码

本文出自 “永不言弃” 博客,请务必保留此出处http://spikeking.blog.51cto.com/5252771/1388136