Алгоритмы

Рекурсивное нахождение суммы элементов списка, в который входят другие списки

Описание задачи

Программа принимает на вход список со вложенными списками и находит сумму элементов всех вложенных списков при помощи рекурсии.

Решение задачи

  1. Инициализируем переменную списком, в котором содержатся вложенные списки.
  2. Передаем этот список в качестве аргумента в рекурсивную функцию для вычисления суммы всех элементов.
  3. В теле этой функции используем одновременно цикл и рекурсию, для того чтобы достать все элементы из вложенных списков и сложить их друг с другом.
  4. На выходе функции выдается сумма всех элементов всех вложенных списков. Причем вложенных списков может быть сколько угодно.
  5. Выводим этот результат на экран.
  6. Конец.

Исходный код

Ниже дан исходный код, который осуществляет нахождение суммы всех элементов списка со вложенными списками при помощи рекурсии. Результаты работы программы также даны ниже.

def sum1(lst):
    total = 0
    for element in lst:
        if (type(element) == type([])):
            total = total + sum1(element)
        else:
            total = total + element
    return total
print("Сумма элементов равна:", sum1([[1, 2], [3, 4]]))

Объяснение работы программы

  1. Инициализируем переменную списком, в котором содержатся вложенные списки.
  2. Передаем этот список в качестве аргумента в рекурсивную функцию sum1() для вычисления суммы всех элементов.
  3. В теле этой функции создаем переменную total, в которой будем суммировать элементы списков.
  4. Далее используем цикл for и рекурсию одновременно — для того, чтобы достать все элементы из вложенных списков и сложить их друг с другом.
  5. На выходе функции выдается сумма всех элементов всех вложенных списков. Причем вложенных списков может быть сколько угодно.
  6. Выводим этот результат на экран.

Результаты работы программы

Пример 1:
Сумма элементов равна: 10
Ilyaragalin

Recent Posts

7 наилучших библиотек визуализации Python на 2024 год

Python предлагает набор библиотек, удовлетворяющих различные потребности в визуализации, будь то академические исследования, бизнес-аналитика или…

3 дня ago

Как преобразовать строку в байты в Python

В Python для представления данных в двоичной форме можно использовать байты. Из этой статьи вы…

2 недели ago

Что такое Werkzeug?

В этой статье рассказывается о том, что такое Werkzeug и как Flask использует его для…

2 недели ago

Как прибавить дни, месяцы и годы к дате в Python

При работе с датами часто возникает необходимость прибавлять к дате или вычитать из нее различные…

3 недели ago

Социальная аутентификация в приложении на Flask

В этом руководстве мы рассмотрим, как добавить социальную аутентификацию с помощью GitHub и Google в…

1 месяц ago

Проверка типов в Python

В этой статье мы рассмотрим, что такое подсказки типов и чем они могут быть полезны.…

1 месяц ago