C++利用兩個棧實現(xiàn)隊列的方法
1. 基礎(chǔ)
隊列:先進(jìn)先出,即插入數(shù)據(jù)在隊尾進(jìn)行,刪除數(shù)據(jù)在隊頭進(jìn)行;
棧:后進(jìn)先出,即插入與刪除數(shù)據(jù)均在棧頂進(jìn)行。
2. 思路
兩個棧實現(xiàn)一個隊列的思想:用pushStack棧作為push數(shù)據(jù)的棧,用popStack棧作為pop數(shù)據(jù)的棧。
- 只要是對隊列進(jìn)行push操作,就將數(shù)據(jù)push入pushStack棧中。
- 要實現(xiàn)隊列的pop操作,有二點原則,如果popStack為空的話那么我們就將pushStack所有的元素放到popStack中,然后取popStack棧頂元素就是隊列的隊頭;如果popStack不為空的話,我們就直接獲取popStack的棧頂元素。
- 對于top操作來說和pop操作類似,只是最后一步不用pop了。
3. 代碼
#include <iostream> #include <stack> #include <exception> template<class T> class MyQueue { public: void push(const T& num); // 入隊列 T pop(); // 出隊列 T top(); private: std::stack<T> pushStack; std::stack<T> popStack; }; template<typename T> void MyQueue<T>::push(const T& num) { pushStack.push(num); } template<typename T> T MyQueue<T>::pop() { if (pushStack.empty() && popStack.empty()) { // 如果二個棧都為空 throw std::runtime_error("queue is empty"); } else if (popStack.empty()) { // 如果popStack為空,將pushStack全部元素倒popStack while (!pushStack.empty()) { T data = pushStack.top(); // 獲取pushStack棧頂元素 pushStack.pop(); // 出棧 popStack.push(data); } } T data = popStack.top(); popStack.pop(); return data; } template<typename T> T MyQueue<T>::top() { if (pushStack.empty() && popStack.empty()) { // 如果二個棧都為空 throw std::runtime_error("queue is empty"); } else if (popStack.empty()) { // 如果popStack為空,將pushStack全部元素倒popStack while (!pushStack.empty()) { T data = pushStack.top(); // 獲取pushStack棧頂元素 pushStack.pop(); // 出棧 popStack.push(data); } } else { // 如果popStack不為空的話直接返回popStack棧頂 T data = popStack.top(); return data; } } int main() { MyQueue<int> myQueue1; myQueue1.push(1); myQueue1.push(2); myQueue1.push(3); myQueue1.push(4); std::cout << "current pop is:" << myQueue1.pop() << std::endl; std::cout << "current pop is:" << myQueue1.pop() << std::endl; std::cout << "current pop is:" << myQueue1.pop() << std::endl; std::cout << "current pop is:" << myQueue1.pop() << std::endl; std::cout << "current pop is:" << myQueue1.pop() << std::endl; return 0; }
4. 參考文獻(xiàn)
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。
相關(guān)文章
matlab遺傳算法求解車間調(diào)度問題分析及實現(xiàn)源碼
這篇文章主要為大家介紹了matlab遺傳算法求解車間調(diào)度問題解析,文中附含詳細(xì)實現(xiàn)源碼,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-02-02VisualStudio2019解決scanf函數(shù)報錯問題
在 Visual Studio 2019 編輯代碼時,前期剛剛接觸到VS編譯器時存在的困惑,當(dāng)用scanf()函數(shù),進(jìn)行輸入時,在運行的時候編譯器會出現(xiàn)警告報錯,本文就來介紹一下解決方法2023-08-08基于Linux系統(tǒng)調(diào)用--getrlimit()與setrlimit()函數(shù)的方法
本篇文章是對在Linux系統(tǒng)中調(diào)用getrlimit()與setrlimit()函數(shù)的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05Windows下Qt讀取系統(tǒng)的內(nèi)存、CPU、GPU等使用信息的示例代碼
在當(dāng)今計算機應(yīng)用廣泛的領(lǐng)域中,了解系統(tǒng)的內(nèi)存、CPU和GPU使用情況是非常重要的,本文將介紹如何使用Qt和Windows API來讀取系統(tǒng)的內(nèi)存、CPU和GPU使用詳細(xì)信息,將提供一個完整的示例代碼,需要的朋友可以參考下2024-01-01