柱状图中的最大矩形


  1. 题目
  2. 代码运行效果
  3. 完整代码

练习题目

在这里插入图片描述

  此题类似我上一个练习“盛最多水的容器”,可以说完全一样,都是查找给定数组中两个数能构成的最大矩形。原题是用递归解的,我弄不来递归,只能用遍历来解。借用了“盛最多水的容器”的代码。🤪

回首页

代码运行效果

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述


回首页

python完整代码
(如果从语句注释不能清楚作用,请评论区留言指教和探讨。🤝)
#/usr/bin/nve python
# coding: utf-8
import os


def clear():
    '''Linux清屏'''
    l = os.system('clear')


def sum_max(nums):
    '''计算柱状图中的最大矩形面积'''
    max_s = 0 #初始化最大面积
    #遍历列表所有元素两两构成的最大矩形面积,找出最大值
    for i, j in enumerate(nums): #枚举内置函数enumerate()同时获取元素位置和元素值。
        for m, n in enumerate(nums):
            min = j
            if j>n:
                min =n
            s = abs(i-m)*min
            if s>max_s:
                max_s = s
    return max_s


#main codes
stacks = [
[2, 1, 5, 6, 2, 3],
[1, 1, 1, 6, 9, 8],
[4, 7, 9, 4, 6, 9, 8, 3, 8]
        ] #定义输入数列
line = '﹊'*21 #一条插值字符串格式化语句定制输出最后结果变量
line0 = '\n'*6
for i in stacks:
    result = sum_max(i)
    clear()
    input(f'{line0}\n柱状数列:{i}\n{line}\n    柱状图中最大矩形:{result}\n{line}\n')

回首页

我的博文推荐:

    Logo

    权威|前沿|技术|干货|国内首个API全生命周期开发者社区

    更多推荐