LeetCode第11題: maxArea(C語言)

上一題:LeetCode第10題: isMatch(C語言)
思路:
1宿崭、基本解法
思路:建立兩層循環(huán)亲铡,分別計(jì)算數(shù)組兩個(gè)元素的乘積,與記錄的最大值比較

int maxArea(int* height, int heightSize) {
    int max_area = 0;
    for(int i = 0; i < heightSize; i++){
        for(int j = heightSize - 1; j >= 0 && j > i; j--){
            int min_height = 0;
            if(height[i] - height[j] > 0){
                min_height = height[j];
            }
            else{
                min_height = height[i];
            }
            if((j - i) * min_height > max_area)
                max_area = (j - i) * min_height;
        }
    }
    return max_area;
}

自然葡兑,暴力破解的方法無法在LeetCode中檢查通過奖蔓。
2、改進(jìn)解法
思路:假設(shè)最優(yōu)解的左右下標(biāo)分別為 i讹堤,j 吆鹤,則面積area = min(height[i], height[j]) * (j - i),這就要求 j 和 i盡量的遠(yuǎn)洲守,這就希望 i 離數(shù)組左邊界最近檀头, j 離數(shù)組右邊界最近轰异。最理想的情況自然是最優(yōu)解 i = 0,j = heightSize - 1暑始, 當(dāng)然面積還跟 min(height[i], height[j])有關(guān)搭独,我們可以從數(shù)組左右邊界開始遍歷數(shù)組,并比較記錄最大值廊镜。
假設(shè) 輸入height = [1,8,6,2,5,4,8,3,7]牙肝,heightSize = 9:
對于 i = 0,j = heightSize - 1 = 8嗤朴,height[i] <height[j]的時(shí)候
min(height[i], height[j]) = height[i] = 1配椭;則area = height[0] * (8 - 0)= 8;對于木桶左邊界為 i = 0時(shí)雹姊,假設(shè)右邊界還可能是比當(dāng)前的最右邊界 j = 8還小的下標(biāo)來作為最優(yōu)解存在
假設(shè)為k股缸,則k < j,對于面來說吱雏,new_area = min(height[i], height[k]) * (k - i)敦姻, 因?yàn)?k < j, 則若要new_area > area歧杏,必須要求min(height[i], height[k]) > min(height[i], height[j]) 镰惦,現(xiàn)在用反證法證明這種情況不存在:
情況一:當(dāng)height[k] > height[i]時(shí),min(height[i], height[k]) = height[i]犬绒,new_area = height[i] * (k - i) 旺入,由于k < j,所以new_area < area凯力;
情況二:當(dāng)height[k] < height[i]時(shí)茵瘾,min(height[i], height[k]) = height[k],new_area = height[k] * (k - i) 咐鹤,由于k < j龄捡,且height[k] < height[i],所以new_area < area慷暂;
綜上聘殖,對于木桶左邊界為i = 0,height[i] <height[j]時(shí)行瑞,最大桶的面積的右邊界 j = heightSize - 1 = 8奸腺;
既然木桶左邊界為i = 0,height[i] <height[j]的情況已經(jīng)確定下來血久,則對于木桶的左邊界突照,可以從 i = 1開始重新進(jìn)入上述邏輯,比較height[i] 氧吐、height[j]的大小讹蘑,然后用min(height[i], height[j]) 作為桶一側(cè)的邊界的高度進(jìn)行計(jì)算末盔,然后用計(jì)算面積最大值和 i = 0時(shí)的記錄做比較即可。
結(jié)論:從數(shù)組兩側(cè)邊界向中間靠攏座慰,每次計(jì)算min(height[i], height[j]) 陨舱,不比回溯計(jì)算,進(jìn)而減少一層循環(huán)遍歷可解決版仔,時(shí)間復(fù)雜度為N游盲。

int maxArea(int* height, int heightSize){
    int i = 0,j = heightSize - 1;
    int area;
    int result = 0;
    while(i < j)
    {
        if(height[i] < height[j])
        {
            area=height[i] * (j - i);
            int m = i + 1;
            while(m < j && height[m] <= height[i]){
                m++;
            }
            i = m;
        }
        else
        {
            area = height[j]*(j - i);
            int n = j - 1;
            while(n > i && height[n] <= height[j]){
                n--;
            }
            j = n;
        }
        if(result < area)
            result = area;
    }
    return result;

}

本系列文章,旨在打造LeetCode題目解題方法蛮粮,幫助和引導(dǎo)同學(xué)們開闊學(xué)習(xí)算法思路益缎,由于個(gè)人能力和精力的局限性,也會(huì)參考其他網(wǎng)站的代碼和思路然想,如有侵權(quán)莺奔,請聯(lián)系本人刪除。
下一題:LeetCode第12題: intToRoman(C語言)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末变泄,一起剝皮案震驚了整個(gè)濱河市令哟,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌杖刷,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件驳癌,死亡現(xiàn)場離奇詭異滑燃,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)颓鲜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進(jìn)店門表窘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人甜滨,你說我怎么就攤上這事乐严。” “怎么了衣摩?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵昂验,是天一觀的道長。 經(jīng)常有香客問我艾扮,道長既琴,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任泡嘴,我火速辦了婚禮甫恩,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘酌予。我一直安慰自己磺箕,他們只是感情好奖慌,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著松靡,像睡著了一般简僧。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上击困,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天涎劈,我揣著相機(jī)與錄音,去河邊找鬼阅茶。 笑死蛛枚,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的脸哀。 我是一名探鬼主播蹦浦,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼撞蜂!你這毒婦竟也來了盲镶?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤蝌诡,失蹤者是張志新(化名)和其女友劉穎溉贿,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體浦旱,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡宇色,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了颁湖。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片宣蠕。...
    茶點(diǎn)故事閱讀 39,981評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖甥捺,靈堂內(nèi)的尸體忽然破棺而出抢蚀,到底是詐尸還是另有隱情,我是刑警寧澤镰禾,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布皿曲,位于F島的核電站,受9級特大地震影響吴侦,放射性物質(zhì)發(fā)生泄漏谷饿。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一妈倔、第九天 我趴在偏房一處隱蔽的房頂上張望博投。 院中可真熱鬧,春花似錦盯蝴、人聲如沸毅哗。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽虑绵。三九已至尿瞭,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間翅睛,已是汗流浹背声搁。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留捕发,地道東北人疏旨。 一個(gè)月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像扎酷,于是被迫代替她去往敵國和親檐涝。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,933評論 2 355