Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Python: dict, hashtable, slot, open addressing, rehash

Как устроен словарь (dict) в Python? Какая структура данных лежит в его основе?

Проверяет понимание внутренней реализации dict как хеш‑таблицы.

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

dict в CPython реализован на основе хеш‑таблицы с открытой адресацией. Ключи хешируются, индекс указывает на слот в массиве записей, где хранится пара (хеш, ключ, значение). При росте таблицы происходит расширение и перехеширование.

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

Хеш‑таблица: массив слотов фиксированного размера, расширяемый по порогу заполненности (≈2/3).

Открытая адресациия: при коллизии применяется алгоритм perturbation для поиска следующего индекса.

Каждый слот хранит:

  • Поле с хешем, ключ и значение.

Расширение:

  • При достижении заполненности таблица удваивается, и все пары перехешируются.

Сохранение порядка:

  • С Python 3.7 порядок вставки поддерживается встроенно.

  • Аватар

    Python Guru

    Sergey Filichkin

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

Уровень

  • Рейтинг:

    2

  • Сложность:

    5

Навыки

  • Python

    Python

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

#dict

#hashtable

#slot

#open addressing

#rehash

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

  • Аватар

    Python Guru

    Sergey Filichkin

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