成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

Largest Rectangle in Histogram

vvpvvp / 2257人閱讀

摘要:而最大的矩形一定滿(mǎn)足兩個(gè)邊界的高度小于該矩形的高度這個(gè)條件如果不滿(mǎn)足的話(huà),邊界也可以被添加進(jìn)來(lái)計(jì)算而不破壞矩形的形狀,此時(shí)不為最大,因此找出所有這樣的矩形就一定可以在其中找出面積最大的矩形。

Problem

Given n non-negative integers representing the histogram"s bar height where the width of each bar is 1, find the area of largest rectangle in the histogram.

Above is a histogram where width of each bar is 1, given height = [2,1,5,6,2,3].

The largest rectangle is shown in the shaded area, which has area = 10 unit.

For example,
Given height = [2,1,5,6,2,3],
return 10.

Solution
暴力窮舉法

最簡(jiǎn)單的自然是暴力法,即窮舉左端坐標(biāo)和右端坐標(biāo),計(jì)算兩個(gè)坐標(biāo)之間矩形的最大面積,再?gòu)乃械拿娣e中得出最大的即為解。但是該方法至少需要兩個(gè)for循環(huán)來(lái)遍歷每一種左右端的組合,時(shí)間復(fù)雜度為O($n^2$)。以下是該方法的代碼,解是對(duì)的,但在leetcode上會(huì)超時(shí)。

class Solution:
    # @param height, a list of integer
    # @return an integer
    def largestRectangleArea(self, height):
        length = len(height)
        max_area = -1
        for i in range(length):
            for j in range(i + 1, length):
                h = min(height[i: j])
                area = h * (j - i)
                if max_area < area:
                    max_area = area
        return max_area
利用棧減小時(shí)間復(fù)雜度

可以考慮,計(jì)算一個(gè)矩形的面積時(shí),比如圖

中的斜線(xiàn)部分,其兩側(cè)的高度一定是低于矩形所在的矩形條的高度的,因此可以通過(guò)維護(hù)一個(gè)棧來(lái)得出左端左邊及右端坐標(biāo)和矩形的高度,每一個(gè)矩形條只進(jìn)棧一次,這樣時(shí)間復(fù)雜度為O(n)。
1. 算法從左向右遍歷每個(gè)矩形,以當(dāng)前遍歷的位置為右端坐標(biāo),如果棧為空或者當(dāng)前矩形不低于棧頂?shù)木匦危瑒t將當(dāng)前的位置坐標(biāo)壓棧,因?yàn)榇藭r(shí)的坐標(biāo)一定不是右邊界(指要計(jì)算的面積右邊的一個(gè)矩形條,不包含在要計(jì)算的面積中),例如圖中,加入當(dāng)前坐標(biāo)為3,高度為6,棧頂坐標(biāo)的高度為5,那么當(dāng)前矩形條不可能作為右邊界,將其壓棧。
2. 如果當(dāng)前位置的矩形低于棧頂?shù)木匦螚l,那么當(dāng)前位置可以作為一個(gè)矩形的邊界,則從這個(gè)位置開(kāi)始向左遍歷,對(duì)每個(gè)高度大于右邊界的矩形條作為左邊界計(jì)算一次面積,直到高度小于右邊界或棧為空。
3. 在遍歷過(guò)一遍之后,如果棧不為空,則以棧中的每個(gè)坐標(biāo)作為左邊界計(jì)算一次面積,結(jié)合步驟2得出最大面積。
Accepted code如下:

class Solution:
    # @param height, a list of integer
    # @return an integer
    def largestRectangleArea(self, height):
        max_area = 0
        i = 0
        n = len(height)
        stack = []
        while i < n:
            if len(stack) == 0 or height[i] >= height[stack[-1]]:
                stack.append(i)
                i += 1
            else:
                top = stack.pop()
                area_with_top = height[top] * (i if len(stack) == 0 else i - stack[-1] - 1)
                if max_area < area_with_top:
                    max_area = area_with_top

        while len(stack) != 0:
            top = stack.pop()
            area_with_top = height[top] * (i if len(stack) == 0 else i - stack[-1] - 1)
            if max_area < area_with_top:
                max_area = area_with_top

        return max_area

這個(gè)方法并不是提供一個(gè)準(zhǔn)確的找出最大的矩形的算法,而是通過(guò)試驗(yàn)?zāi)切翱赡堋背蔀樽畲蟮木匦蔚拿娣e,再?gòu)钠渲姓页鲎畲蟮?。而最大的矩形一定滿(mǎn)足兩個(gè)邊界的高度小于該矩形的高度這個(gè)條件(如果不滿(mǎn)足的話(huà),邊界也可以被添加進(jìn)來(lái)計(jì)算而不破壞矩形的形狀,此時(shí)不為最大),因此找出所有這樣的矩形就一定可以在其中找出面積最大的矩形。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/37307.html

相關(guān)文章

  • [LeetCode] 84. Largest Rectangle in Histogram

    Problem Given n non-negative integers representing the histograms bar height where the width of each bar is 1, find the area of largest rectangle in the histogram. showImg(https://segmentfault.com/img...

    BaronZhang 評(píng)論0 收藏0
  • [Leetcode] Largest Rectangle (in Histogram) 最大矩形

    摘要:以此類(lèi)推,如果一直到棧為空時(shí),說(shuō)明剛出來(lái)的豎條之前的所有豎條都比它自己高,不然不可能棧為空,那我們以左邊全部的寬度作為長(zhǎng)方形的寬度。 Largest Rectangle in Histogram Given n non-negative integers representing the histograms bar height where the width of each bar...

    鄒強(qiáng) 評(píng)論0 收藏0
  • [LintCode] Largest Rectangle in Histogram

    摘要:只要出現(xiàn)當(dāng)前右邊界高度小于等于棧頂元素高度的情況,就取出棧頂元素當(dāng)前遍歷過(guò)最高的并對(duì)這個(gè)元素進(jìn)行取最大矩形的運(yùn)算。 Problem Given n non-negative integers representing the histograms bar height where the width of each bar is 1, find the area of largest ...

    alighters 評(píng)論0 收藏0
  • leetcode84. Largest Rectangle in Histogram

    摘要:題目要求即找到圖中可以組合而成的面積最大的矩形。從而我們可以知道該矩形在水平方向上的最大擴(kuò)展程度。也就是說(shuō),棧中數(shù)據(jù)記錄了最遠(yuǎn)左側(cè)下標(biāo),而當(dāng)前的矩形則是最遠(yuǎn)右側(cè)下標(biāo)。當(dāng)我們不采用數(shù)據(jù)結(jié)構(gòu)時(shí),尋找和計(jì)算的過(guò)程需要的時(shí)間復(fù)雜度。 題目要求 Given n non-negative integers representing the histograms bar height where t...

    Harpsichord1207 評(píng)論0 收藏0
  • 84. Largest Rectangle in Histogram

    摘要:要求一個(gè)矩形的面積,要知道高和寬。如果每次確定高度為然后調(diào)用一個(gè)找到左右邊界,即不小于的最左和最右。這是一個(gè)明顯的算法,每次掃描都會(huì)重走整個(gè)。一個(gè)遞增序列這種,我們知道可以夠成的矩形是會(huì)不斷增大的。遞增序列預(yù)處理,遞減的時(shí)候計(jì)算。 showImg(https://segmentfault.com/img/bVoQel); For example, Given heights = [2,...

    melody_lql 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<