11. Container With Most Water

2018-03-10  本文已影响0人  Jonddy
题目要求:

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 and n is at least 2.

解题思路:
代码:
class Solution(object):
    def maxAreatwo(self, height):

        max_area, i, j = 0, 0, len(height) - 1
        while i < j:
            max_area = max(max_area, min(height[i], height[j]) * (j - i))
            if height[i] < height[j]:
                i += 1
            else:
                j -= 1
        return max_area


if __name__ == "__main__":
    height = [1, 2, 1, 4, 1, 5, 1]
    result = Solution().maxAreatwo(height)
    print(result)


上一篇下一篇

猜你喜欢

热点阅读