Leetcode 42. Trapping Rain Water

Given n non-negative integers representing an elevation map where the width of each bar is 1, compute how much water it is able to trap after raining.

雙指針:把題意簡化到左右高已知秩伞,中間部分全部低于左右兩邊刑巧,就很容易求出能放多少水,因此對于這道題,可以用雙指針一直記錄當前左右兩邊的最大值。

棧:如果利用棧福青,我們從左到右每把一個元素放入棧內(nèi)時犹菱,可以看它是否比棧頂元素的高度大,如果比棧頂大肪跋,則說明當前元素可以當做之前這個元素的一個右邊欄,如果比棧頂小土砂,則棧頂元素可以當做當前元素的一個左邊欄州既。

動態(tài)規(guī)劃:如果對于每個元素,我們能知道它左邊最大的高度(包括它自身)萝映,右邊最大的高度(包括它自身)易桃,那么對于這個元素的位置能放的最大水量,就等于它左右兩邊較小的最大高度減去自身高度锌俱。遍歷完整個數(shù)組晤郑,對每個位置的最大水量求和就是總最大水量。

//雙指針法
public int trap(int[] height) {
        if (height == null || height.length < 2) {
            return 0;
        }

        int len = height.length - 1;
        int left = 0, leftMax = 0, right = len, rightMax = 0;
        int maxWater = 0;

        while (left < right) {
            if (height[left] <= height[right]) {
                if (height[left] > leftMax) {
                    leftMax = height[left];
                } else {
                    maxWater += leftMax - height[left];
                }
                left++;
            } else {
                if (height[right] > rightMax) {
                    rightMax = height[right];
                } else {
                    maxWater += rightMax - height[right];
                }
                right--;
            }
        }

        return maxWater;
    }

  //單調(diào)棧
  public int trap(int[] height) {
        if (height == null || height.length < 2) {
            return 0;
        }

        int maxWater = 0;
        Stack<Integer> stack = new Stack<>();
        for (int i = 0; i < height.length; i++) {
            while (!stack.empty() && height[stack.peek()] < height[i]) {
                int preHeight = height[stack.pop()];
                if (stack.empty()) {
                    break;
                }
                int dis = i - stack.peek() - 1;
                int hDiff = Math.min(height[i], height[stack.peek()]) - preHeight;
                maxWater += dis * hDiff;
            }
            stack.push(i);
        }

        return maxWater;
    }

  //動態(tài)規(guī)劃
  public int trapDp(int[] height) {
        if (height == null || height.length < 2) {
            return 0;
        }

        int maxWater = 0;
        int size = height.length;

        int[] leftMax = new int[size];
        leftMax[0] = height[0];
        for (int i = 1; i < size; i++) {
            leftMax[i] = Math.max(leftMax[i-1], height[i]);
        }

        int[] rightMax = new int[size];
        rightMax[size-1] = height[size-1];
        for (int i = size - 2; i >= 0; i--) {
            rightMax[i] = Math.max(rightMax[i+1], height[i]);
        }

        for (int i = 0; i < size; i++) {
            maxWater += Math.min(leftMax[i], rightMax[i]) - height[i];
        }

        return maxWater;
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末贸宏,一起剝皮案震驚了整個濱河市造寝,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌吭练,老刑警劉巖诫龙,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異鲫咽,居然都是意外死亡签赃,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進店門分尸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來堆巧,“玉大人肠套,你說我怎么就攤上這事族壳∈崆龋” “怎么了?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵材蛛,是天一觀的道長圆到。 經(jīng)常有香客問我,道長卑吭,這世上最難降的妖魔是什么芽淡? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮豆赏,結(jié)果婚禮上挣菲,老公的妹妹穿的比我還像新娘富稻。我一直安慰自己,他們只是感情好己单,可當我...
    茶點故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著耙饰,像睡著了一般纹笼。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上苟跪,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天廷痘,我揣著相機與錄音,去河邊找鬼件已。 笑死笋额,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的篷扩。 我是一名探鬼主播兄猩,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼鉴未!你這毒婦竟也來了枢冤?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤铜秆,失蹤者是張志新(化名)和其女友劉穎淹真,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體连茧,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡核蘸,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了啸驯。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片客扎。...
    茶點故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖罚斗,靈堂內(nèi)的尸體忽然破棺而出虐唠,到底是詐尸還是另有隱情,我是刑警寧澤惰聂,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布疆偿,位于F島的核電站,受9級特大地震影響搓幌,放射性物質(zhì)發(fā)生泄漏杆故。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一溉愁、第九天 我趴在偏房一處隱蔽的房頂上張望处铛。 院中可真熱鬧饲趋,春花似錦、人聲如沸撤蟆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽家肯。三九已至龄砰,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間讨衣,已是汗流浹背换棚。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留反镇,地道東北人固蚤。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像歹茶,于是被迫代替她去往敵國和親夕玩。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,722評論 2 345

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