兩個佇列實現乙個棧

2021-07-15 13:12:25 字數 513 閱讀 4436

棧是 後進先出,佇列是 先進先出  

思路:建立兩個佇列去q1, q2 , q1存放資料的前n-1項,q2存放最後一項 。

過程:資料全放在 q1 , 前面的n-1個元素 放到q2 ,出q1

上**:

templateclass stack_by_2queue

q1.push(data);

} void pop()

q2.pop();

} t& top()

/**/

return q1.back();

} bool empty()

size_t size()

private:

queueq1;

queueq2;

};

前面還有用 兩個棧實現乙個佇列。

其實,這些主要是對於棧和佇列的學習的練習,寫的不愛好的地方,希望大家給出意見。

兩個棧實現乙個佇列 兩個佇列實現乙個棧

這兩個題的思路比較相似。棧的特點是 先進後出 佇列的特點是 先進先出 不要怕!用兩個棧實現乙個佇列很簡單 再將top元素push到stack 2中,然後將stack 1 pop一次直到stack 1剩下最後乙個元素,這個就是最先push進去的,我們把它pop掉就可以了,同理,我們求queue的fro...

兩個棧實現乙個佇列,兩個佇列實現乙個棧

1 兩個棧實現乙個佇列 入隊時,直接壓入stack1中。出隊時,判斷stack2是否為空,如果stack2為空,則將stack1中的元素倒入stack2中,否則直接彈出stack2中的元素。入隊操作 void enqueue stack s1,stack s2,int m 出隊操作 void deq...

兩個棧實現乙個佇列 兩個佇列實現乙個棧

方法一 public class main 出棧操作 public int deletehead while stack1.isempty return stack2.pop 方法二 public class main public int deletehead throws exception i...