最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 【算法】[困难]-直方图的水量-动态规划

    正文概述 掘金(叫我詹躲躲)   2021-04-03   793

    17.21. 直方图的水量

    难度:[困难]

    给定一个直方图(也称柱状图),假设有人从上面源源不断地倒水,最后直方图能存多少水量?直方图的宽度为 1。

    【算法】[困难]-直方图的水量-动态规划

    上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的直方图,在这种情况下,可以接 6 个单位的水(蓝色部分表示水)。 感谢 Marcos 贡献此图。

    示例:

    输入: [0,1,0,2,1,0,1,3,2,1,2,1]
    输出: 6
    

    【思路】动态规划

    1.记录height中的每个元素,从左向右扫描并记录右边的最大高度;
    2.记录height中的每个元素,从右向左扫描并记录右边的最大高度;
    3.将左右位置元素对比取最小的元素,减去数组当前元素的高度。

    从左向右扫描并记录右边的最大高度

    【算法】[困难]-直方图的水量-动态规划

    从右向左扫描并记录右边的最大高度

    【算法】[困难]-直方图的水量-动态规划

    取高度最小值

    【算法】[困难]-直方图的水量-动态规划

    Javascript

    var trap = function (height) {
        let len = height.length
        if (len === 0) return 0
        //记录左边每个矩形最大高度
        let left = Array(len).fill(0)
        left[0] = height[0]
        for (let i = 1; i < len; ++i) {
            left[i] = Math.max(left[i - 1], height[i])
        }
        //记录右边每个矩形最大高度
        let right = Array(len).fill(0)
        right[len - 1] = height[len - 1]
        for (let i = len - 2; i >= 0; --i) {
            right[i] = Math.max(right[i + 1], height[i])
        }
        //记录结果
        let ret = 0
        for (let i = 0; i < len; ++i) {
            //左右对比取最小边界,减去当前矩形高度
            ret += Math.min(left[i], right[i]) - height[i]
        }
        return ret
    };
    

    go

    func trap(height []int) int {
    	n := len(height)
    	if n == 0 {
    		return 0
    	}
    	//记录左边每个元素最大高度
    	leftMax := make([]int, n)
    	leftMax[0] = height[0]
    	for i := 1; i < n; i++ {
    		leftMax[i] = max(leftMax[i-1], height[i])
    	}
    	//记录左边每个元素最大高度
    	rightMax := make([]int, n)
    	rightMax[n-1] = height[n-1]
    	for i := n - 2; i >= 0; i-- {
    		rightMax[i] = max(rightMax[i+1], height[i])
    	}
    	fmt.Println(leftMax, rightMax)
    	ret := 0
    	for j := 0; j < n; j++ {
    		ret += (min(leftMax[j], rightMax[j]) - height[j])
    	}
    	return ret
    }
    
    //由于Go语言里面没有max(),min()需要自己实现一个
    func max(a, b int) int {
    	if a-b > 0 {
    		return a
    	}
    	return b
    }
    func min(a, b int) int {
    	if a-b > 0 {
    		return b
    	}
    	return a
    }
    

    Typescript

    function trap(height) {
        var len = height.length;
        if (len === 0)
            return 0;
        //记录左边每个矩形最大高度
        var left = Array(len);
        left[0] = height[0];
        for (var i = 1; i < len; ++i) {
            left[i] = Math.max(left[i - 1], height[i]);
        }
        //记录右边每个矩形最大高度
        var right = Array(len);
        right[len - 1] = height[len - 1];
        for (var i = len - 2; i >= 0; --i) {
            right[i] = Math.max(right[i + 1], height[i]);
        }
        //记录结果
        var ret = 0;
        for (var i = 0; i < len; ++i) {
            //左右对比取最小边界,减去当前矩形高度
            ret += Math.min(left[i], right[i]) - height[i];
        }
        return ret;
    }
    

    python

    class Solution(object):
        def trap(self, height):
            """
            :type height: List[int]
            :rtype: int
            """
            if not height:
                return 0
            # 数组长度
            n = len(height)
    
            # 记录左边每个矩形最大高度
            left = [0]*n
            left[0] = height[0]
            for i in range(1,n):
                left[i] = max(left[i - 1], height[i])
    
            # 记录右边每个矩形最大高度
            right = [0]*n
            right[n - 1] = height[n - 1]
            for i in range(n-2,-1,-1):
                right[i] = max(right[i + 1], height[i])
            # 记录结果
            ret = sum(min(left[i], right[i]) - height[i] for i in range(n)) 
            return ret
    

    继续加油!哦里给


    起源地下载网 » 【算法】[困难]-直方图的水量-动态规划

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元