Пример решения задачи #11. Python LeetCode, Контейнер с большим количеством воды

Опубликовано: 13.12.2024, 13:42 | Автор: hdhAI

Вариант решения задачи на языке программирования Python с LeetCode.
Категория: Алгоритмы.
Название задачи: Контейнер с большим количеством воды.
Сложность: Средняя.
Статус решения: "Решено".

Условие задачи:
Вам дан целочисленный массив высотой длины n. Нарисовано n вертикальных линий, конечными точками которых являются (i, 0) и (i, высота[i]).

Найдите две линии, которые вместе с осью X образуют контейнер, в котором содержится больше всего воды.

Возвращайте максимальное количество воды, которое может хранить контейнер. Примечание: контейнер наклонять нельзя.

Ввод: height = [1,8,6,2,5,4,8,3,7]
Вывод: 49
Пояснение: Вышеупомянутые вертикальные линии представлены массивом [1,8,6,2,5,4,8,3,7]. В этом случае максимальная площадь воды (синяя секция на картинке), которую может содержать контейнер, равна 49.

Источник изображения: leetcode.com

Решение:


Python

class Solution(object):
    def maxArea(self, height):
        """
        :type height: List[int]
        :rtype: int
        """
        # Инициализируем два указателя: левый (left) и правый (right), а также переменную для хранения максимальной площади (max_area)
        left = 0
        right = len(height) - 1
        max_area = 0

        # Используем двухуказательный подход для нахождения максимальной площади
        while left < right:
            # Вычисляем текущую ширину контейнера
            width = right - left
            # Вычисляем текущую площадь, ограничиваясь меньшей из высот двух указателей
            current_area = width * min(height[left], height[right])
            # Обновляем максимальную площадь, если текущая больше
            max_area = max(max_area, current_area)

            # Двигаем указатели: уменьшаем меньшую высоту для возможного увеличения площади
            if height[left] < height[right]:
                left += 1
            else:
                right -= 1

        # Возвращаем максимальную площадь
        return max_area

Объяснение кода


Инициализация указателей и переменной для площади:
Мы используем два указателя left (начало массива) и right (конец массива), чтобы проверять все возможные пары линий, начиная с самых крайних. max_area инициализируем значением 0, так как это минимально возможная площадь.

Основная логика:
В цикле while мы продолжаем сравнивать линии, пока указатели не встретятся.

На каждой итерации:
1) Вычисляем ширину контейнера как расстояние между указателями: width = right - left.
2) Определяем минимальную высоту из двух линий: min(height[left], height[right]), так как именно она ограничивает высоту воды.
3) Вычисляем текущую площадь: current_area = width * min(height[left], height[right]).
4) Сравниваем текущую площадь с максимальной, и если она больше, обновляем max_area.

Движение указателей:
Чтобы увеличить вероятность нахождения большего контейнера, мы двигаем указатель, связанный с меньшей высотой. Это связано с тем, что перемещение большей высоты не увеличит максимальную площадь.

Возвращаем результат:
После завершения цикла возвращаем max_area, что и будет ответом.

Источник решения: hdhai.com

Похожие статьи
Интересное





Warning: file_put_contents(/var/www/angella1/data/www/hdhai.com/counter/count.php): Failed to open stream: Permission denied in /var/www/angella1/data/www/hdhai.com/counter.php on line 89