Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Войти

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

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

© 2026 YeaHub

Документы

Медиа

Назад
Вопрос про JavaScript: run, length, encoding

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

Проверяет знание базовых алгоритмов, работы со строками и оценки сложности.

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

Простейший алгоритм сжатия строки — это run-length encoding, при котором одинаковые символы заменяются символом и количеством повторений. Например, aaabb превращается в a3b2. Такой алгоритм выполняется за O(n), так как строка проходит один раз.

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

Один из самых простых способов сжатия строки — алгоритм RLE (Run-Length Encoding).

Идея алгоритма

Определение:
RLE — это метод сжатия, при котором последовательности одинаковых символов заменяются символом и количеством повторений.

Пример

aaabcccc → a3b1c4

Пример реализации

function compress(str) {
  let result = "";
  let count = 1;

  for (let i = 1; i <= str.length; i++) {
    if (str[i] === str[i - 1]) {
      count++;
    } else {
      result += str[i - 1] + count;
      count = 1;
    }
  }
  return result;
}

Оценка сложности

  • Временная сложность: O(n)

  • Пространственная сложность: O(n)

Причина:

  • строка проходит один раз

  • результат хранится отдельно

Где применяется

  • простые форматы сжатия

  • кодирование данных

  • обработка логов

Вывод

RLE — простой алгоритм сжатия, который удобен для задач с повторяющимися символами и хорошо демонстрирует оценку сложности.

Уровень

  • Рейтинг:

    3

  • Сложность:

    6

Навыки

  • JavaScript

    JavaScript

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

#run

#length

#encoding

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