由兩個棧組成的隊(duì)列

題目

編寫一個類宣渗,用兩個棧實(shí)現(xiàn)隊(duì)列抖所,支持隊(duì)列的基本操作(add, poll, peek)

要求

思路

使用兩個棧,棧A用于add痕囱,棧B用于poll和peek田轧,add的時候,往棧A中push元素鞍恢,poll時傻粘,如果棧B不是空,則彈出最頂元素有序,如果為空則將棧A的所有元素pop抹腿,然后push到棧B中。這樣就可以實(shí)現(xiàn)隊(duì)列的功能了旭寿。

代碼

package com.github.zhanyongzhi.interview.algorithm.stacklist;

import java.util.Stack;

/**
 * 用兩個棧實(shí)現(xiàn)隊(duì)列
 * @author zhanyongzhi
 */
public class TwoStackQueue<T> {
    private Stack<T> pushStack = new Stack<T>();
    private Stack<T> popStack = new Stack<T>();

    public T add(T item){
        pushStack.push(item);
        return item;
    }

    public T poll(){
        if(popStack.empty()){
            moveStack();
        }

        if(!popStack.empty())
            return popStack.pop();

        return null;
    }

    public T peek(){
        if(popStack.empty()){
            moveStack();
        }

        if(!popStack.empty())
            return popStack.peek();

        return null;
    }

    private void moveStack(){
        int count = pushStack.size();
        for(int i=0; i<count; i++){
            T item = pushStack.pop();
            popStack.push(item);
        }
    }
}

在github中查看

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末警绩,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子盅称,更是在濱河造成了極大的恐慌肩祥,老刑警劉巖后室,帶你破解...
    沈念sama閱讀 218,755評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異混狠,居然都是意外死亡岸霹,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評論 3 395
  • 文/潘曉璐 我一進(jìn)店門将饺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來贡避,“玉大人,你說我怎么就攤上這事予弧」伟桑” “怎么了?”我有些...
    開封第一講書人閱讀 165,138評論 0 355
  • 文/不壞的土叔 我叫張陵掖蛤,是天一觀的道長杀捻。 經(jīng)常有香客問我,道長蚓庭,這世上最難降的妖魔是什么致讥? 我笑而不...
    開封第一講書人閱讀 58,791評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮器赞,結(jié)果婚禮上垢袱,老公的妹妹穿的比我還像新娘。我一直安慰自己拳魁,他們只是感情好惶桐,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著潘懊,像睡著了一般姚糊。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上授舟,一...
    開封第一講書人閱讀 51,631評論 1 305
  • 那天救恨,我揣著相機(jī)與錄音,去河邊找鬼释树。 笑死肠槽,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的奢啥。 我是一名探鬼主播秸仙,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼桩盲!你這毒婦竟也來了寂纪?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎捞蛋,沒想到半個月后孝冒,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,724評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡拟杉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年庄涡,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片搬设。...
    茶點(diǎn)故事閱讀 40,040評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡穴店,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出焕梅,到底是詐尸還是另有隱情迹鹅,我是刑警寧澤卦洽,帶...
    沈念sama閱讀 35,742評論 5 346
  • 正文 年R本政府宣布贞言,位于F島的核電站,受9級特大地震影響阀蒂,放射性物質(zhì)發(fā)生泄漏该窗。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評論 3 330
  • 文/蒙蒙 一蚤霞、第九天 我趴在偏房一處隱蔽的房頂上張望酗失。 院中可真熱鬧,春花似錦昧绣、人聲如沸规肴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽拖刃。三九已至,卻和暖如春贪绘,著一層夾襖步出監(jiān)牢的瞬間兑牡,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評論 1 270
  • 我被黑心中介騙來泰國打工税灌, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留均函,地道東北人。 一個月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓菱涤,卻偏偏與公主長得像苞也,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子粘秆,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評論 2 355

推薦閱讀更多精彩內(nèi)容