zoukankan      html  css  js  c++  java
  • 求柱状图中最大的矩形

    问题:

    # 给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。 
    #
    # 求在该柱状图中,能够勾勒出来的矩形的最大面积。

    方法一:暴力

    # leetcode submit region begin(Prohibit modification and deletion)
    class Solution(object):
        def largestRectangleArea(self, heights):
            """
            :type heights: List[int]
            :rtype: int
            """
            length = len(heights)
            max_area = 0
            for i in range(length):
                min_height = math.inf
                for j in range(i, length):
                    min_height = min(min_height, heights[j])
                    area = min_height * (j-i+1)
                    max_area = max(area, max_area)
            return max_area
    # leetcode submit region end(Prohibit modification and deletion)

    方法二:优化,遍历每个柱子,左右扩展找满足条件的左柱和右柱

    # leetcode submit region begin(Prohibit modification and deletion)
    class Solution(object):
        def largestRectangleArea(self, heights):
            """
            :type heights: List[int]
            :rtype: int
            """
            length = len(heights)
            max_area = 0
            for i in range(length):
                current_height = heights[i]
                left = right = i
                while (left-1 >= 0 and heights[left-1] >= current_height):
                    left -= 1
                while (right+1 < length and heights[right+1] >= current_height):
                    right += 1
                max_area = max(max_area, (right-left+1) * current_height)
            return max_area
    # leetcode submit region end(Prohibit modification and deletion)
    时刻记着自己要成为什么样的人!
  • 相关阅读:
    挑战程序设计竞赛第二章、贪心部分
    Life is Strange:《奇异人生》
    算法竞赛进阶指南第二章--题解
    算法竞赛进阶指南第一章题解
    2018 IEEE极限编程大赛 题解
    爬格子呀9.17(图论)
    大数模板(加减乘除幂次开方)
    地理位置(Geolocation)API 简介
    javascript闭包的理解
    H5本地离线存储
  • 原文地址:https://www.cnblogs.com/demo-deng/p/14777449.html
Copyright © 2011-2022 走看看