stack1用於存放入隊的元素,以壓棧的方式壓入stack1,但是這樣取出的順序是反的,所以將stack2當作中轉站,這樣順序就變成先進先出了。
入隊:先判斷stack1是否已滿。如果已滿,則以出棧順序全部壓入stack2。然後再入隊。如果不滿,則直接入隊即可。
出隊:先判斷stack2是否為空。如果為空,先將stack1中內容全部出棧壓入stack2,然後再出隊。如果不為空,則直接出隊即可。
class solution
int pop()
else}}
int top=stack2.top();
stack2.pop();
return top;
}private:
stackstack1;
stackstack2;
};
c++ stl的stack的使用參見我的另外一篇部落格:c++ stl容器——stack用法介紹 劍指offer 用兩個棧實現佇列
華電北風吹 天津大學認知計算與應用重點實驗室 日期 2015 9 30 題目描述 用兩個棧來實現乙個佇列,完成佇列的push和pop操作。佇列中的元素為int型別。解析 我的思路是用乙個棧來儲存資料,入隊的話直接在這個棧上入棧,出隊的話借助輔助棧,對輔助棧入棧,然後取出頭元素,然後把輔助棧上的元素在...
用兩個棧實現佇列《劍指offer
題目描述 用兩個棧來實現乙個佇列,完成佇列的push和pop操作。佇列中的元素為int型別。解題思路 將元素入隊時壓入乙個棧中,隨後通過另乙個棧出隊 1 使用stack容器定義兩個棧 stack stack1 stack stack2 2 入隊 stack1.push node node為入隊元素 ...
劍指offer 用兩個棧實現佇列
記錄 劍指offer 上的演算法題。題目描述如下 佇列的宣告如下 template class cqueue cqueue t deletehead bool empty private stack stack1 stack stack2 實現的 如下 templatet stack1.push n...