日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

美团笔试最大矩形面积

發布時間:2024/4/17 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 美团笔试最大矩形面积 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
給定一組非負整數組成的數組h,代表一組柱狀圖的高度,其中每個柱子的寬度都為1。 在這組柱狀圖中找到能組成的最大矩形的面積(如圖所示)。 入參h為一個整型數組,代表每個柱子的高度,返回面積的值。 這個問題和前面我們講過的一個盛最多水的容器很相似,不同的地方是這個邊界可以不為首尾,因為內部也可能存在更大面積的矩形,而那個題目要求以兩個邊界為前提,組成的容器。上次我準備用dp來解決,沒有成功,那是因為原理不符,沒有最優子結構。這個問題就可以用dp來解決了。 首先我們來看,存在最優子結構,如果目前存在最大的矩形的面積,再加一個柱子,我們可以判斷出加上它,最大的矩形面積。然后這個子問題也是重疊的,在加不加新柱子的問題上,我們判斷最大矩形面積的方法是一樣的,唯一不同的是邊界不同,也就對應的參數不同。另外問題的邊界也存在,就是我們輸入的這幾個高度。子問題的求解也是獨立的。 int main() {int n;cin >> n;vector<long> h(n+1);for (int i = 1; i <= n; i++)cin >> h[i];vector<vector<long>> dp(n+1, vector<long>(n+1));for (int i = 1; i <= n; i++)dp[i][i] = h[i];int min_h;// for (int i = n-1; i >= 1; i--)// {//for (int j = i; j <= n; j++)// {// min_h = h[i];// for (int k = i; k <= j; k++)// min_h = min_h < h[k] ? min_h : h[k];// dp[i][j] = (min_h *(j - i + 1)) > dp[i][j - 1] ? (min_h *(j - i + 1)) : dp[i][j - 1];// dp[j][i] = dp[i][j] = dp[i][j] > dp[i + 1][j] ? dp[i][j] : dp[i + 1][j];// }// }for (int j = 1; j<=n; j++){for (int i = j-1; i >= 1; i--){min_h = h[i];for (int k = i; k <= j; k++)min_h = min_h < h[k] ? min_h : h[k]; dp[i][j] = (min_h *(j - i + 1)) > dp[i][j - 1] ? (min_h *(j - i + 1)) : dp[i][j - 1];dp[j][i] = dp[i][j] = dp[i][j] > dp[i + 1][j] ? dp[i][j] : dp[i + 1][j];}}for(int i=0;i<=n;i++){cout << dp[1][i] << '\0';}return 0; }

這里面,dp[i][j]代表從i到j的最大矩形面積。首先dp[i][i]就是該高度下的單個矩形面積。我們需要存儲從i到j的最小高度,因為多加一個柱狀圖,我們需要判斷以最小高度為高的矩形面積,比原來的最大矩形面積相比的結果。我們需要通過比較dp[i][j-1]和dp[i+1][j]以及新計算的面積三個來得到dp[i][j]。程序中加黑字體中,第一行將dp[i][j-1]和新面積相比,將最大值賦給了dp[i][j],但是這并不是最終的結果,因為如果dp[i+1][j]中的面積要大于這兩個,我們就會漏掉。所以第二行也很必要。一定不能丟。

上述的過程不好理解的話,就理解下邊界情況,如果就兩個直方圖,我們需要比較這兩個單獨的面積以及兩個并在一起的面積,必須比較完這三個才能得到最大的面積。

(2)其實這道題還可以用單調棧來做,具體做法見上一篇《單調棧以及應用》,這里不再贅述。

轉載于:https://www.cnblogs.com/mini-coconut/p/9108434.html

總結

以上是生活随笔為你收集整理的美团笔试最大矩形面积的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 青青草97国产精品免费观看 | 超碰超碰97 | 黄色生活毛片 | 日日摸天天爽天天爽视频 | 久久久国产精品人人片 | 精品人妻少妇嫩草av无码专区 | 亚洲区自拍 | 国产嫩草视频 | 日本在线有码 | 五月深爱婷婷 | 亚洲aaa视频 | 亚洲av永久无码精品 | 国产一级二级三级视频 | 夜夜操狠狠干 | 九色精品 | 91免费国产在线 | 免费在线观看小视频 | 五月激情六月婷婷 | 小罗莉极品一线天在线 | 美女激情网站 | 一道本av在线 | 日韩一级网站 | 中文字幕一区二区人妻痴汉电车 | 国产在线视频一区二区 | 成人在线超碰 | 青青草99 | 青青草视频免费播放 | 下面一进一出好爽视频 | 伊人久久国产 | 亚洲天堂久久久 | 欧美黑大粗 | 伊人久久婷婷 | 色婷婷热久久 | 97人妻精品一区二区三区免费 | 亚洲一区二区三区四区在线观看 | 一级片a级片 | 国模私拍视频在线 | 亚洲美女视频一区 | 中文字幕有码在线观看 | 少妇视频一区 | 亚洲精品一区二区三区区别 | 天天影视色 | www,久久久 | 天天操天天射天天爽 | av鲁丝一区二区鲁丝 | 日p免费视频 | 日韩欧美影院 | 妖精视频在线观看 | 色播久久 | 91热爆视频 | 泰剧19禁啪啪无遮挡 | 丰腴饱满的极品熟妇 | 9999免费视频 | 在线看中文字幕 | 永久av在线免费观看 | 亚洲精品毛片av | 免费观看一区二区 | 直接看av的网站 | 国产精品久久久久国产a级 国产一区二区在线播放 | 久久免费av | 色呦呦网站 | 精品无码国产一区二区三区51安 | 免费一级淫片aaa片毛片a级 | 亚洲综合伊人久久 | a v免费视频 | 久久视频一区 | 亚洲欧美日本另类 | 日韩一区二区三区四区在线 | 午夜小视频网站 | xxxxxhd亚洲人hd| 91在线看视频| 国产盗摄精品一区二区酒店 | 一级片在线免费看 | 亚洲成人生活片 | 久色免费视频 | 先锋影音av中文字幕 | 最新av导航 | 成人wwxx免费观看 | 香蕉视频 | 久久久久久久国产 | 狠狠澡 | 日本一区二区三区视频免费看 | 久久亚洲网站 | www啪啪 | 91大奶 | 精品无码一级毛片免费 | 天天干天天色天天 | 免费视频国产 | 美女黄色小视频 | 国产福利一区二区视频 | 国产黄色的视频 | 欧美日韩国产一区在线 | 玖玖国产 | 91深夜福利| 在线观看成年人网站 | 国产成年人 | jk美女又爽又黄视频 | 国产午夜麻豆影院在线观看 | 国产免费美女 |