Container With Most Water

來源:互聯網
上載者:User

標籤:java   leetcode   數組   

題目

Given n non-negative integers a1, a2, ..., an, where each represents a point at coordinate (i, ai). n vertical lines are drawn such that the two endpoints of line i is at (i, ai) and (i, 0). Find two lines, which together with x-axis forms a container, such that the container contains the most water.

Note: You may not slant the container.

方法
選出兩條線,使其面積最大。遍曆一遍即可。
    public int maxArea(int[] height) {        if (height == null || height.length == 0 || height.length == 1) {            return 0;        }        int len = height.length;        int left = 0;        int right = len - 1;        int area = 0;        while (left < right) {        int temp = Math.min(height[left], height[right]) * (right - left);        if (temp > area) {        area = temp;        }        if (height[left] < height[right]) {        left++;        } else {        right--;        }        }        return area;    }


聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.