Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Math: naive, algorithm

Как оценить временную сложность наивной реализации скользящего среднего?

Вопрос проверяет умение анализировать вложенные циклы и оценивать сложность базовых алгоритмов.

Короткий ответ

Наивная реализация пересчитывает среднее заново для каждого окна. Если размер окна равен k, а длина данных — n, то для каждого из n шагов выполняется k операций. Итоговая сложность такого алгоритма — O(n · k).

Длинный ответ

Наивный подход часто используется как первое решение, но он плохо масштабируется.

Определение

Наивная реализация скользящего среднего — это алгоритм, который на каждом шаге заново суммирует все элементы текущего окна.

Пример наивного алгоритма

for i in range(n - k + 1):
    window_sum = 0
    for j in range(k):
        window_sum += data[i + j]

Анализ сложности

  1. внешний цикл выполняется n раз,

  2. внутренний цикл выполняется k раз,

  3. общее число операций — n · k.

Частные случаи

  • если k — константа, сложность близка к O(n),

  • если k ≈ n, сложность становится O(n²).

Практические последствия

  • плохо подходит для больших окон,

  • быстро становится узким местом по времени.

Вывод

Наивная реализация имеет сложность O(n · k) и подходит только для небольших данных или учебных примеров.

  • Аватар

    Python Guru

    Sergey Filichkin

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    4

  • Сложность:

    4

Навыки

  • Math

    Math

Ключевые слова

#naive

#algorithm

Подпишись на Python Developer в телеграм

  • Аватар

    Python Guru

    Sergey Filichkin

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.