找出面积最大的矩形

Posted newsunls

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了找出面积最大的矩形相关的知识,希望对你有一定的参考价值。

描述

在一个平面图上,有多个宽度固定为1,高度不同的矩形并列排着,在这些矩形所组成的图形中,能够切割出的最大矩形的面积是多少? 数据范围:0 < 高度 < 100

举例:高度为2,3,2的三个矩形所组成的图形,能够切割出的最大的矩形面积为6。见下图。

技术分享图片

输入

 

一组正整数,分别用逗号隔开,表示每个矩形的高度

 

输出

 

一个整数,表示组合成的最大的矩形面积

 

输入样例

2,3,2
5,6,7,8,3

 复制样例

输出样例

6
20

def solution(line):
    nums=list(map(int,line.split(,)))

    def getMaxArr(arr,number):
        s=[]

        if len(arr)==0:
            return 0
        for i in range(len(arr)):
            if (i==0 or arr[i-1]<number) and arr[i]>=number:
                s.append([i,0])
            if i==len(arr)-1 or (arr[i-1]>=number and arr[i]<number):
                if len(s)>0:
                    if i==len(arr)-1 and arr[i]>=number:
                        s[-1][1]=i+1
                    else:
                        s[-1][1]=i
        are=0
        for i in s:
            are=max(are,max(len(arr[i[0]:i[1]])*number,getMaxArr(arr[i[0]:i[1]],number+1)))
        return are


    return getMaxArr(nums,1)

 



以上是关于找出面积最大的矩形的主要内容,如果未能解决你的问题,请参考以下文章

ccf--20131203--最大矩形

直方图中最大矩形面积

Leetcode 84 求直方图中矩形的最大面积

栈的灵活实际应用——直方图最大矩形面积

Java 求解柱状图中最大的矩形

85.最大矩形