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、處理左邊一半:從左往右計算柱子高度極大值與當(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)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗。 張土汪:刷leetcod...
    土汪閱讀 12,890評論 0 33
  • 雨整夜,夢難尋, 輾轉(zhuǎn)反側(cè)照無眠,不聞窗外蟲鳴聲,唯聞檐下雨落聲, 天曉欲曙時,卻還昏暗,恍如入夜, 臥看斜雨紛紛...
    35f8a119f405閱讀 106評論 0 2
  • 母親已有六十九個日夜不曾跟我講一句話?!_篇第一句話,就是有文字素描特色的文字,六十九個,這個明確的數(shù)字。 能在...
    April2005閱讀 1,384評論 0 0
  • 沒有結(jié)局博物館之前是一座小鎮(zhèn)。 小鎮(zhèn)的人們把沒有結(jié)局的故事留在房子里,然后帶走了自己。 再后來,路過的旅客也常常在...
    喵喵僧閱讀 536評論 5 6

友情鏈接更多精彩內(nèi)容