2020-08-27 C#中ref變量的理解 && 劍指 Offer 09. 用兩個(gè)棧實(shí)現(xiàn)隊(duì)列

Ref變量

變量作為參數(shù)傳給方法,同時(shí)希望在方法執(zhí)行完成后这弧,對(duì)參數(shù)所做的修改能夠反映到變量上
如果在一段代碼中調(diào)用了一個(gè)函數(shù)娃闲,該函數(shù)使用了當(dāng)前代碼段中的變量,當(dāng)函數(shù)執(zhí)行完畢返回后匾浪,該變量仍然保持著函數(shù)中的值皇帮,相當(dāng)于ref類(lèi)型的變量是忽略了函數(shù)中局部變量的限制的變量。

劍指 Offer 09. 用兩個(gè)棧實(shí)現(xiàn)隊(duì)列

用兩個(gè)棧實(shí)現(xiàn)一個(gè)隊(duì)列蛋辈。隊(duì)列的聲明如下属拾,請(qǐng)實(shí)現(xiàn)它的兩個(gè)函數(shù) appendTail 和 deleteHead ,分別完成在隊(duì)列尾部插入整數(shù)和在隊(duì)列頭部刪除整數(shù)的功能冷溶。(若隊(duì)列中沒(méi)有元素渐白,deleteHead 操作返回 -1 )

示例 1:

輸入:
["CQueue","appendTail","deleteHead","deleteHead"]
[[],[3],[],[]]
輸出:[null,null,3,-1]
示例 2:

輸入:
["CQueue","deleteHead","appendTail","appendTail","deleteHead","deleteHead"]
[[],[],[5],[2],[],[]]
輸出:[null,-1,null,null,5,2]

題意其實(shí)就是用兩個(gè)棧實(shí)現(xiàn)隊(duì)列的入隊(duì)與出隊(duì)操作(隊(duì)尾添加與隊(duì)列去頭)
其中處理appendTail有輸入值,以及deleteHead有輸出值外逞频,其他的輸出全為Null
綜上所述即可理解題意

解決方法

public class CQueue {
    private Stack<int> stack1;
    private Stack<int> stack2;
    public CQueue() {
        stack1 = new Stack<int>();//初始化纯衍,其中stack1負(fù)責(zé)入棧,stack2負(fù)責(zé)出棧
        stack2 = new Stack<int>();
    }
    
    public void AppendTail(int value) {
        stack1.Push(value);//入隊(duì)操作苗胀,與入棧操作無(wú)異
    }
    
    public int DeleteHead() {//出隊(duì)操作
        if(stack2.Count == 0){//首先判斷負(fù)責(zé)出隊(duì)的棧stack2是否為空
            while(stack1.Count != 0){//不為空則講stack1中的元素循環(huán)入棧stack2
                stack2.Push(stack1.Pop());
            }
        }
        if(stack2.Count == 0){//再次判斷stack2是否為空托酸,此時(shí)是為了檢測(cè)是否隊(duì)列為空(因?yàn)樯厦嬉约皩tack1入棧到stack2了,如果stack1為空則stack2此時(shí)也為空柒巫,所以此時(shí)說(shuō)明隊(duì)列為空励堡,返回-1
            return -1;
        }else{
            int deleteItem = stack2.Pop();//stack2最后加入的元素出棧,既隊(duì)列去頭
            return deleteItem;//返回出棧元素
        }

    }
}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末堡掏,一起剝皮案震驚了整個(gè)濱河市应结,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌泉唁,老刑警劉巖鹅龄,帶你破解...
    沈念sama閱讀 211,123評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異亭畜,居然都是意外死亡扮休,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門(mén)拴鸵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)玷坠,“玉大人蜗搔,你說(shuō)我怎么就攤上這事“吮ぃ” “怎么了樟凄?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,723評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)兄渺。 經(jīng)常有香客問(wèn)我缝龄,道長(zhǎng),這世上最難降的妖魔是什么挂谍? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,357評(píng)論 1 283
  • 正文 為了忘掉前任叔壤,我火速辦了婚禮,結(jié)果婚禮上口叙,老公的妹妹穿的比我還像新娘百新。我一直安慰自己,他們只是感情好庐扫,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,412評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布饭望。 她就那樣靜靜地躺著,像睡著了一般形庭。 火紅的嫁衣襯著肌膚如雪铅辞。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,760評(píng)論 1 289
  • 那天萨醒,我揣著相機(jī)與錄音斟珊,去河邊找鬼。 笑死富纸,一個(gè)胖子當(dāng)著我的面吹牛囤踩,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播晓褪,決...
    沈念sama閱讀 38,904評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼堵漱,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了涣仿?” 一聲冷哼從身側(cè)響起勤庐,我...
    開(kāi)封第一講書(shū)人閱讀 37,672評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎好港,沒(méi)想到半個(gè)月后愉镰,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,118評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡钧汹,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,456評(píng)論 2 325
  • 正文 我和宋清朗相戀三年丈探,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片拔莱。...
    茶點(diǎn)故事閱讀 38,599評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡碗降,死狀恐怖隘竭,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情遗锣,我是刑警寧澤,帶...
    沈念sama閱讀 34,264評(píng)論 4 328
  • 正文 年R本政府宣布嗤形,位于F島的核電站精偿,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏赋兵。R本人自食惡果不足惜笔咽,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,857評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望霹期。 院中可真熱鬧叶组,春花似錦、人聲如沸历造。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,731評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)吭产。三九已至侣监,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間臣淤,已是汗流浹背橄霉。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,956評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留邑蒋,地道東北人姓蜂。 一個(gè)月前我還...
    沈念sama閱讀 46,286評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像医吊,于是被迫代替她去往敵國(guó)和親钱慢。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,465評(píng)論 2 348