12阁苞、Trapping Rain Water

Problem Description

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.

For example,
Given [0,1,0,2,1,0,1,3,2,1,2,1], return 6.

The above elevation map is represented by array [0,1,0,2,1,0,1,3,2,1,2,1]. In this case, 6 units of rain water (blue section) are being trapped. Thanks Marcos for contributing this image!

Analyze

1讨盒、找出最高的柱子,以此柱為中線將數(shù)組分為兩半
2筏餐、處理左邊一半:從左往右計(jì)算柱子高度極大值與當(dāng)前柱子高度差
3鸿秆、處理右邊一半:從右往左同2

Code

class Solution {
    func trap(heights: [Int]) -> Int {
        let n = heights.count
        var water = 0
        var max: Int = 0
       
        for (i, value) in heights.enumerate() {
            if value > heights[max] {
                max = i //找出最高的柱子 將數(shù)組分為兩半
            }
        }
        
        var peak = 0 // 謹(jǐn)記數(shù)據(jù)越界問題, 不能取heights[0]
         for value in heights[0..<max] {
            if value < peak {
                water += peak - value
            }
            else if value > peak {
                peak = value
            }
        }
        
        var top = 0
        for value in heights[max..<n].reverse() {
            if value < top {
                water += top - value
            }
            else if value > top {
                top = value
            }
        }
        
        return water
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市帚稠,隨后出現(xiàn)的幾起案子谣旁,更是在濱河造成了極大的恐慌,老刑警劉巖滋早,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件榄审,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡杆麸,警方通過查閱死者的電腦和手機(jī)搁进,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來昔头,“玉大人饼问,你說我怎么就攤上這事〗腋” “怎么了莱革?”我有些...
    開封第一講書人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長讹开。 經(jīng)常有香客問我盅视,道長,這世上最難降的妖魔是什么旦万? 我笑而不...
    開封第一講書人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任闹击,我火速辦了婚禮,結(jié)果婚禮上成艘,老公的妹妹穿的比我還像新娘赏半。我一直安慰自己贺归,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開白布除破。 她就那樣靜靜地躺著牧氮,像睡著了一般。 火紅的嫁衣襯著肌膚如雪瑰枫。 梳的紋絲不亂的頭發(fā)上踱葛,一...
    開封第一講書人閱讀 49,166評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音光坝,去河邊找鬼尸诽。 笑死,一個(gè)胖子當(dāng)著我的面吹牛盯另,可吹牛的內(nèi)容都是我干的性含。 我是一名探鬼主播,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼鸳惯,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼商蕴!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起芝发,我...
    開封第一講書人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤绪商,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后辅鲸,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體格郁,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年独悴,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了例书。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡刻炒,死狀恐怖决采,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情坟奥,我是刑警寧澤织狐,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站筏勒,受9級(jí)特大地震影響移迫,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜管行,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一厨埋、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧捐顷,春花似錦荡陷、人聲如沸雨效。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽徽龟。三九已至,卻和暖如春唉地,著一層夾襖步出監(jiān)牢的瞬間据悔,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來泰國打工耘沼, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留极颓,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓群嗤,卻偏偏與公主長得像菠隆,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子狂秘,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344

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

  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗(yàn)骇径。 張土汪:刷leetcod...
    土汪閱讀 12,724評(píng)論 0 33
  • 雨整夜,夢(mèng)難尋者春, 輾轉(zhuǎn)反側(cè)照無眠既峡,不聞窗外蟲鳴聲,唯聞檐下雨落聲碧查, 天曉欲曙時(shí),卻還昏暗校仑,恍如入夜忠售, 臥看斜雨紛紛...
    35f8a119f405閱讀 89評(píng)論 0 2
  • 母親已有六十九個(gè)日夜不曾跟我講一句話∑——開篇第一句話稻扬,就是有文字素描特色的文字,六十九個(gè)羊瘩,這個(gè)明確的數(shù)字泰佳。 能在...
    April2005閱讀 1,215評(píng)論 0 0
  • 沒有結(jié)局博物館之前是一座小鎮(zhèn)。 小鎮(zhèn)的人們把沒有結(jié)局的故事留在房子里尘吗,然后帶走了自己逝她。 再后來,路過的旅客也常常在...
    喵喵僧閱讀 440評(píng)論 5 6