如何使用棧模擬一個隊列


隊列先進先出。

棧先進后出。

最近看到一道面試題,要求用兩個棧模擬一個隊列,這個問題在一年前遇到過,記錄一下。

使用棧模擬隊列,一個肯定不行,首先想到用兩個棧來模擬隊列。

當隊列有數據要入隊時,我們同時將這個數據入棧A

此時我們認為,第一次向隊列中插入數據完成了。則我們將A中的數據彈出,使用B來接收這些值。

就這樣將A中的元素全部彈出並且壓進B中,這時就會發現,他們順序逆轉,並且如同隊列一樣,先進的元素到了棧頂,可以先出。

我們讓1出隊之后,此時我們還想繼續向隊列中添加數據。

 

 

此時,2依然是棧B放在棧頂的元素。此時有新的元素加入,我們依然采取剛才的方法,在新數據入隊時,插入數據到棧A中。

 插入棧A之后,我們可以對棧B進行判斷,如果棧B中還存有元素,則這名剛才添加的元素尚未全部出隊,他們仍然遵守先進先出的原則。

當棧B中的元素全部彈出之后,我們就可以將棧A中的元素再次彈出並壓進棧B,此時又實現了先進先出。

代碼實現:

  1. private Stack<Integer> stackA = new Stack<Integer>();

  2. private Stack<Integer> stackB = new Stack<Integer>();

  3.  

  4. /**

  5. * 入隊操作

  6. * @param element 入隊的元素

  7. */

  8. public void enQueue(int element) {

  9. stackA.push(element);

  10. }

  11.  

  12. /**

  13. * 出隊操作

  14. */

  15. public Integer deQueue() {

  16. if(stackB.isEmpty()){

  17. if(stackA.isEmpty()){

  18. return null;

  19. }

  20. transfer();

  21. }

  22. return stackB.pop();

  23. }

  24. ``

  25. ``

  26. /**

  27. * 棧A元素轉移到棧B

  28. */

  29. private void transfer(){

  30. while (!stackA.isEmpty()){

  31. stackB.push(stackA.pop());

  32. }

  33. }

  34. ``

  35. ``

  36. public static void main(String[] args) throws Exception {

  37. StackQueue stackQueue = new StackQueue();

  38. stackQueue.enQueue(1);

  39. stackQueue.enQueue(2);

  40. stackQueue.enQueue(3);

  41. System.out.println(stackQueue.deQueue());

  42. System.out.println(stackQueue.deQueue());

  43. stackQueue.enQueue(4);

  44. System.out.println(stackQueue.deQueue());

  45. System.out.println(stackQueue.deQueue());

  46. }


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM