題解——單調(diào)棧

單調(diào)棧題解

單調(diào)棧結(jié)構(gòu)

欧慕玻客鏈接

方法:單調(diào)棧

算法

這里維護(hù)一個(gè)單調(diào)遞增棧墩瞳,可以找到比當(dāng)前元素要小的元
約定:當(dāng)前元素 cur售滤,棧頂元素 top,出棧的棧頂元素 tempTop

  • 遍歷數(shù)組
  • 如果當(dāng)前元素大于棧頂元素悄雅,則入棧(入棧元素索引驱敲,而不是值)
  • 否則,將棧頂元素出棧煤伟,此時(shí)癌佩,離 tempTop 左邊最近且值比 tempTop 小的就是當(dāng)前的棧頂元素 top木缝,離 tempTop 右邊最近且值比 tempTop 小的就是當(dāng)前元素 cur。 然后循環(huán)此過程围辙,直到第二步條件滿足我碟。
  • 遍歷數(shù)組結(jié)束后,最后將棧內(nèi)元素按上述規(guī)則輸出
    private static void leftRightWay(int[] arr){
        int len = arr.length;
        int[] right = new int[len];
        int[] left = new int[len];
        Stack<Integer> stack = new Stack<>();
        for(int i = 0; i < len; i++) {
            while(!stack.empty() && arr[i] < arr[stack.peek()]) {
                int tempTop = stack.pop();
                left[tempTop] = stack.empty() ? -1 : stack.peek();
                right[tempTop] = i;
            }
            stack.push(i);
        }

        while(!stack.empty()) {
            int tempTop = stack.pop();
            left[tempTop] = stack.empty() ? -1 : stack.peek();
            right[tempTop] = -1;
        }

        for(int i = 0; i < len; i++) {
            System.out.println(left[i] + " " + right[i]);
        }
    }

復(fù)雜度

  • 時(shí)間復(fù)雜度:O(N)姚建,每個(gè)元素被處理兩次矫俺,其索引入棧和出棧。

739. 每日溫度

LeetCode 鏈接

方法一:動態(tài)規(guī)劃掸冤,詳解可去鏈接里查看

    public int[] dailyTemperatures(int[] T) {
        int len = T.length;
        int[] result = new int[len];
        result[len - 1] = 0;
        for(int i = len - 2; i >= 0; i--) {
            for(int j = i + 1; j < len; j += result[j]) {
                // 重點(diǎn)在 j += result[j] 上
                // 當(dāng)天溫度小于后一天溫度厘托,那么直接得出結(jié)果 1
                // 當(dāng)天溫度大于后一天溫度,那么就得比較 [比后一天溫度還要高的那一天]稿湿,循環(huán)這個(gè)過程铅匹。
                // 如果后一天溫度的后面沒有比它大的了,那自然也不可能比當(dāng)天溫度大了
                if (T[i] < T[j]) {
                    result[i] = j - i;
                    break;
                } else if (result[j] == 0) {
                    result[i] = 0;
                    break;
                }
            }
        }

        return result;
    }

方法二:單調(diào)棧

算法

維護(hù)一個(gè)單調(diào)遞減的棧即可饺藤,棧內(nèi)存放的是元素索引

  • 遍歷數(shù)組
  • 如果當(dāng)前元素小于棧頂元素包斑,則入棧
  • 否則,將棧頂元素出棧涕俗,當(dāng)前元素索引 - 棧頂元素 就是對應(yīng)位置的結(jié)果
    public int[] dailyTemperatures(int[] T) {
        int len = T.length;
        int[] result = new int[len];
        Stack<Integer> stack = new Stack();
        for(int i = 0; i < len; i++) {
            while(!stack.empty() && T[i] > T[stack.peek()]) {
                int tempTop = stack.pop();
                result[tempTop] = i - tempTop;
            }
            stack.push(i);
        }

        while(!stack.empty()) {
            result[stack.pop()] = 0;
        }

        return result;
    }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末罗丰,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子再姑,更是在濱河造成了極大的恐慌萌抵,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,270評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件元镀,死亡現(xiàn)場離奇詭異绍填,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)栖疑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評論 3 395
  • 文/潘曉璐 我一進(jìn)店門沐兰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蔽挠,你說我怎么就攤上這事」辖” “怎么了澳淑?”我有些...
    開封第一講書人閱讀 165,630評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長插佛。 經(jīng)常有香客問我杠巡,道長,這世上最難降的妖魔是什么雇寇? 我笑而不...
    開封第一講書人閱讀 58,906評論 1 295
  • 正文 為了忘掉前任氢拥,我火速辦了婚禮蚌铜,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘嫩海。我一直安慰自己冬殃,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,928評論 6 392
  • 文/花漫 我一把揭開白布叁怪。 她就那樣靜靜地躺著审葬,像睡著了一般。 火紅的嫁衣襯著肌膚如雪奕谭。 梳的紋絲不亂的頭發(fā)上涣觉,一...
    開封第一講書人閱讀 51,718評論 1 305
  • 那天,我揣著相機(jī)與錄音血柳,去河邊找鬼官册。 笑死,一個(gè)胖子當(dāng)著我的面吹牛难捌,可吹牛的內(nèi)容都是我干的膝宁。 我是一名探鬼主播,決...
    沈念sama閱讀 40,442評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼栖榨,長吁一口氣:“原來是場噩夢啊……” “哼昆汹!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起婴栽,我...
    開封第一講書人閱讀 39,345評論 0 276
  • 序言:老撾萬榮一對情侶失蹤满粗,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后愚争,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體映皆,經(jīng)...
    沈念sama閱讀 45,802評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,984評論 3 337
  • 正文 我和宋清朗相戀三年轰枝,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了捅彻。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,117評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡鞍陨,死狀恐怖步淹,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情诚撵,我是刑警寧澤缭裆,帶...
    沈念sama閱讀 35,810評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站寿烟,受9級特大地震影響澈驼,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜筛武,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,462評論 3 331
  • 文/蒙蒙 一缝其、第九天 我趴在偏房一處隱蔽的房頂上張望挎塌。 院中可真熱鬧,春花似錦内边、人聲如沸榴都。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,011評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽缭贡。三九已至,卻和暖如春辉懒,著一層夾襖步出監(jiān)牢的瞬間阳惹,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,139評論 1 272
  • 我被黑心中介騙來泰國打工眶俩, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留莹汤,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,377評論 3 373
  • 正文 我出身青樓颠印,卻偏偏與公主長得像纲岭,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子线罕,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,060評論 2 355

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