91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

如何用兩個棧來實現一個隊列及其Push和Pop操作

發布時間:2021-12-03 09:12:34 來源:億速云 閱讀:124 作者:柒染 欄目:大數據

如何用兩個棧來實現一個隊列及其Push和Pop操作,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

今天刷的一道題是用兩個棧來表示一個隊列。我們知道棧和隊列的主要區別在于:棧:后進先出 隊列:先進先出。

題目

用兩個棧來實現一個隊列,完成隊列的Push和Pop操作。隊列中的元素為int類型。

分析

需要通過兩個后進先出的棧實現一個先進先出的隊列。如下圖:如何用兩個棧來實現一個隊列及其Push和Pop操作假設往棧stack1 中壓入 1,2,3,4,5,6,7 這幾個數據,如果直接從stack1中取的話,就是7,6,5,4,3,2,1.與我們想要你的先進先出不符合。所以我們將stack1的數據依次出棧并壓入棧stack2 中,這樣再從stack2 中出棧的數據就是1,2,3,4,5,6,7了。但是,上面的這些只考慮了先進棧后壓棧。那如果是進棧出棧交替呢?如何用兩個棧來實現一個隊列及其Push和Pop操作比如初始,向stack1 中壓入 1,2,3.然后,將stack1 中的數據出棧入棧到stack2 中。如何用兩個棧來實現一個隊列及其Push和Pop操作那這個時候,再往stack1 中進棧的話,該怎么壓入棧stack2 中呢?這里其實大家應該注意到,如果stack2 中存在數據,那這些數據應該是最先出棧的,所以直接出棧就好了,不用管stack1 中的數據,因為那些是后來的數據,肯定是是后出棧的。當棧stack2 中沒有數據的時候,再將stack1 中的數據都出棧壓入stack2 中。這樣就可以實現一個隊列的先進先出啦。

解法

進隊列,直接將數據壓入棧stack1 中就好了。

public void push(int node){
       stack1.push(node);
   }

出隊列,先判斷stack2 中是否有數據,有的話,直接從stack2 中出棧。如果沒有,就將stack1 中的數據壓入棧stack2 中。然后再從stack2 中出棧。

public int pop(){
       if(!stack2.isEmpty()){
           return stack2.pop();
       }
       while(!stack1.isEmpty()){
           stack2.push(stack1.pop());
       }
       return stack2.pop();
   }

不過上面的代碼還可以簡化一下,畢竟兩個return stack2.pop(); 有點不舒服。

public int pop(){
       if(stack2.isEmpty()){
           while(!stack1.isEmpty()){
               stack2.push(stack1.pop());
           }
       }
       return stack2.pop();
   }

源代碼:

public class Solution {
   Stack<Integer> stack1=new Stack<>();
   Stack<Integer> stack2=new Stack<>();

   public static void main(String[] args) {
       Solution solution= new Solution();
       solution.push(0);
       solution.push(1);
       solution.push(2);
       solution.push(3);
       solution.push(4);
       solution.push(5);
       System.out.print(solution.pop()+"\t");
       System.out.print(solution.pop()+"\t");
       System.out.print(solution.pop()+"\t");
       solution.push(6);
       solution.push(7);
       solution.push(8);
       System.out.print(solution.pop()+"\t");
       System.out.print(solution.pop()+"\t");
       System.out.print(solution.pop()+"\t");
   }

   public void push(int node){
       stack1.push(node);
   }

   public int pop(){
       if(stack2.isEmpty()){
           while(!stack1.isEmpty()){
               stack2.push(stack1.pop());
           }
       }

       return stack2.pop();
   }
}

測試

如何用兩個棧來實現一個隊列及其Push和Pop操作如何用兩個棧來實現一個隊列及其Push和Pop操作

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

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

AI

缙云县| 清流县| 绩溪县| 南投市| 综艺| 肃宁县| 长白| 广元市| 寿宁县| 贺兰县| 镇江市| 昔阳县| 蓬溪县| 台东县| 上犹县| 崇州市| 正宁县| 榆树市| 桃源县| 波密县| 八宿县| 兴和县| 桦川县| 嘉善县| 宁安市| 潞城市| 大连市| 永年县| 青海省| 苍梧县| 泰和县| 临潭县| 南昌市| 乌兰浩特市| 昌都县| 友谊县| 扎鲁特旗| 府谷县| 阜阳市| 和政县| 瓦房店市|