程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> C++ 中priority_queue 優先級隊列實例詳解

C++ 中priority_queue 優先級隊列實例詳解

編輯:關於C++

C++ 中"priority_queue" 優先級隊列實例詳解。本站提示廣大學習愛好者:(C++ 中"priority_queue" 優先級隊列實例詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是C++ 中"priority_queue" 優先級隊列實例詳解正文


C++ 中"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; 
} 

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved