11.盛最多水的容器

題目描述:給定 n 個(gè)非負(fù)整數(shù) a1,a2,...,an,每個(gè)數(shù)代表坐標(biāo)中的一個(gè)點(diǎn) (i, ai) 。在坐標(biāo)內(nèi)畫 n 條垂直線,垂直線 i 的兩個(gè)端點(diǎn)分別為 (i, ai) 和 (i, 0)。找出其中的兩條線,使得它們與 x 軸共同構(gòu)成的容器可以容納最多的水。
說明:你不能傾斜容器,且 n 的值至少為 2。

示例圖

圖中垂直線代表輸入數(shù)組 [1,8,6,2,5,4,8,3,7]。在此情況下,容器能夠容納水(表示為藍(lán)色部分)的最大值為 49。
示例:
輸入: [1,8,6,2,5,4,8,3,7]
輸出: 49

方法一: 雙向指針
思想:
最初我們考慮由最外圍兩條線段構(gòu)成的區(qū)域?,F(xiàn)在,為了使面積最大化,我們需要考慮更長的兩條線段之間的區(qū)域。如果我們試圖將指向較長線段的指針向內(nèi)側(cè)移動(dòng),矩形區(qū)域的面積將受限于較短的線段而不會(huì)獲得任何增加。但是,在同樣的條件下,移動(dòng)指向較短線段的指針盡管造成了矩形寬度的減小,但卻可能會(huì)有助于面積的增大。因?yàn)橐苿?dòng)較短線段的指針會(huì)得到一條相對(duì)較長的線段,這可以克服由寬度減小而引起的面積減小。

import java.util.ArrayList;
import java.util.Scanner;

public class MaxArea {

    public static int getMaxArea(int[] height) {
        int maxArea = 0;
        int l = 0, r = height.length - 1;
        while(l < r) {
            maxArea = Math.max(maxArea, Math.min(height[l], height[r])*(r - l));
            if (height[l] < height[r]){
                l++;
            } else {
                r--;
            }
        }
        return maxArea;
    }

    public static void main(String[] args) {
        //控制臺(tái)動(dòng)態(tài)輸入數(shù)組
        Scanner scanner = new Scanner(System.in);
        ArrayList<Integer> list = new ArrayList<>();
        while (scanner.hasNext()) {
            String line = scanner.next();
            System.out.println(line);
            if(line != null && line.equals("exit")) {
                break;
            }
            list.add(Integer.valueOf(line));
        }
        //將動(dòng)態(tài)數(shù)據(jù)arrayList轉(zhuǎn)為固定數(shù)組
        int[] height = new int[list.size()];
        for (int i = 0 ; i < list.size(); i++) {
            height[i] = list.get(i);
        }
        System.out.println(getMaxArea(height));
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 摘要 如題意,垂直的兩條線段將會(huì)與坐標(biāo)軸構(gòu)成一個(gè)矩形區(qū)域,較短線段的長度將會(huì)作為矩形區(qū)域的寬度,兩線間距將會(huì)作為矩...
    zzpwestlife閱讀 272評(píng)論 0 2
  • 給定 n 個(gè)非負(fù)整數(shù) a1,a2,...,an,每個(gè)數(shù)代表坐標(biāo)中的一個(gè)點(diǎn) (i, ai) 。在坐標(biāo)內(nèi)畫 n 條垂直...
    LeeYunFeng閱讀 735評(píng)論 0 50
  • 描述: 給定 n 個(gè)非負(fù)整數(shù) a1,a2,...,an,每個(gè)數(shù)代表坐標(biāo)中的一個(gè)點(diǎn) (i, ai) 。在坐標(biāo)內(nèi)畫 n...
    大數(shù)據(jù)Zone閱讀 432評(píng)論 0 1
  • 國慶幾天,在贛州旅游,現(xiàn)在贛州大部分的旅游景點(diǎn)像是沒有長大的小孩子,透露著天真和質(zhì)樸,也像當(dāng)?shù)貨]有被商業(yè)氣息污染的...
    Adagou閱讀 517評(píng)論 0 1
  • 不知不覺中已經(jīng)過了兩個(gè)月,兩個(gè)匆匆奔走的月份。過程是煎熬的,堅(jiān)持是不易的,習(xí)慣是可怕的,后續(xù)是滿意的。 任何事情的...
    Carly咔閱讀 249評(píng)論 0 2

友情鏈接更多精彩內(nèi)容