摘要:而最大的矩形一定滿(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.
最簡(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
可以考慮,計(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
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...
摘要:以此類(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...
摘要:只要出現(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 ...
摘要:題目要求即找到圖中可以組合而成的面積最大的矩形。從而我們可以知道該矩形在水平方向上的最大擴(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...
摘要:要求一個(gè)矩形的面積,要知道高和寬。如果每次確定高度為然后調(diào)用一個(gè)找到左右邊界,即不小于的最左和最右。這是一個(gè)明顯的算法,每次掃描都會(huì)重走整個(gè)。一個(gè)遞增序列這種,我們知道可以夠成的矩形是會(huì)不斷增大的。遞增序列預(yù)處理,遞減的時(shí)候計(jì)算。 showImg(https://segmentfault.com/img/bVoQel); For example, Given heights = [2,...
閱讀 921·2023-04-25 18:51
閱讀 1875·2021-09-09 11:39
閱讀 3285·2019-08-30 15:53
閱讀 2104·2019-08-30 13:03
閱讀 1314·2019-08-29 16:17
閱讀 587·2019-08-29 11:33
閱讀 1888·2019-08-26 14:00
閱讀 2126·2019-08-26 13:41