描述

在一个平面图上,有多个宽度固定为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)