兩個佇列實現乙個棧(C語言)

2021-08-22 00:09:52 字數 478 閱讀 3213

本題的思路是先建立queue1和queue2,入棧時直接向queue1里入佇列,出棧時需要先從queue1中出佇列的同時把數依次進入queue2,直到queue1中到最後乙個數為止,然後將queue1中的數出佇列,再將queue2中的數倒回queue1,這樣就實現了乙個棧。

實現**如下:

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

void stackpush(queue

*p1, qdatatype data)

queuepush(p1, data);

}//兩個佇列實現乙個棧出棧

void stackpop(queue

*p1, queue

*p2)

while (p1->size !=

1)

queuepop(p1);

while (p2->size !=

0)

}

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

這兩個題的思路比較相似。棧的特點是 先進後出 佇列的特點是 先進先出 不要怕!用兩個棧實現乙個佇列很簡單 再將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...