亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++利用兩個棧實現隊列的方法

發布時間:2020-08-23 20:16:40 來源:腳本之家 閱讀:216 作者:alxe_made 欄目:編程語言

1. 基礎

隊列:先進先出,即插入數據在隊尾進行,刪除數據在隊頭進行;

棧:后進先出,即插入與刪除數據均在棧頂進行。

2. 思路

兩個棧實現一個隊列的思想:用pushStack棧作為push數據的棧,用popStack棧作為pop數據的棧。

  1. 只要是對隊列進行push操作,就將數據push入pushStack棧中。
  2. 要實現隊列的pop操作,有二點原則,如果popStack為空的話那么我們就將pushStack所有的元素放到popStack中,然后取popStack棧頂元素就是隊列的隊頭;如果popStack不為空的話,我們就直接獲取popStack的棧頂元素。
  3. 對于top操作來說和pop操作類似,只是最后一步不用pop了。

C++利用兩個棧實現隊列的方法

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. 參考文獻

  • 用兩個棧實現一個隊列——我作為面試官的小結
  • C++之用兩個棧實現一個隊列

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

东乌| 万州区| 闽侯县| 汨罗市| 博兴县| 庆安县| 舟曲县| 无锡市| 都江堰市| 黄骅市| 朝阳县| 临沧市| 乌审旗| 封开县| 张家口市| 信丰县| 璧山县| 元谋县| 峨边| 二手房| 克山县| 成武县| 即墨市| 潼南县| 华安县| 沂水县| 漳州市| 甘南县| 边坝县| 鄱阳县| 三都| 新乡市| 宣城市| 伊宁县| 丰都县| 竹溪县| 汾西县| 绥阳县| 客服| 新邵县| 丹巴县|