656 читали · 3 года назад
Словари, ассоциативные массивы и хеш-таблицы. Структуры данных Python #1
Извиняюсь за задержку, пришлось на время отойти от Дзена. Однако, уже сейчас вы узнаете почему словари в Python — центральная структура данных и какие есть вариации словарей из встроенных библиотек. Начнем! Введение в Python dict Словари в Python — центральная структура данных. В словарях хранится произвольное количество объектов, каждый из которых идентифицируется уникальным ключом словаря.  Словари также нередко называют ассоциативными массивами (associative arrays), ассоциативными хеш-таблицами (hashmaps), поисковыми таблицами (lookup tables) или таблицами преобразования...
4 месяца назад
Хеш-функции в Python: ключ к эффективной работе с данными 🔓 Хеш-функции — это мощный инструмент, который позволяет преобразовать данные произвольного размера в значение фиксированной длины, называемое хешем. В Python они играют важную роль в различных задачах, от хэширования паролей до оптимизации работы словарей. Что такое хеш-функция? Хеш-код, обычно представленный в виде целого числа, намного короче, чем исходные данные. Как это работает? Хеш-функции используют алгоритмы, которые преобразуют данные в хеш-код с помощью математических операций. Они должны обладать следующими свойствами: * Быстрота: Хеш-функция должна быстро генерировать хеш-код. * Детерминированность: Для одних и тех же входных данных хеш-функция всегда должна возвращать один и тот же хеш-код. * Равномерность: Хеш-функция должна равномерно распределять хеш-коды по всему диапазону возможных значений. Зачем использовать хеш-функции? * Хэширование паролей: Хеш-функции преобразуют пароли в хеш-коды, хранящиеся в базе данных вместо самих паролей. Это повышает безопасность, так как злоумышленники не смогут получить доступ к реальным паролям, даже если получат доступ к базе данных. * Проверка целостности данных: Хеш-функции могут использоваться для проверки целостности файлов. Если хеш-код файла изменяется, это означает, что файл был изменен. * Оптимизация словарей: Словари в Python используют хеш-функции для быстрого поиска ключей. Хеш-функция позволяет быстро найти ключ в таблице хешей, а затем проверить, соответствует ли значение ключу. Хеш-функции в Python: Python предоставляет различные хеш-функции: * hash(x): Стандартная хеш-функция Python. * md5(): Создает хеш-код MD5. * sha1(): Создает хеш-код SHA-1. * sha256(): Создает хеш-код SHA-256. Пример:import hashlib # Хеширование строки с помощью SHA-256 data = "Hello, world!" hash_object = hashlib.sha256(data.encode()) hex_digest = hash_object.hexdigest() print(hex_digest) # Выведет: 9114c68635c3a740d350f92e821281a554c2b6525c1915944c3f50b8a5827c3f Хеш-функции — это важный инструмент для работы с данными в Python. Они позволяют обеспечить безопасность, проверить целостность данных и оптимизировать работу с структурами данных. Хорошая хеш-функция должна обладать следующими свойствами: - Лавинообразный эффект - Быстрое вычисление - Минимальное количество коллизий - Равномерное распределение хешей 🔥 Чтобы сузить диапазон хеш-значений пользуются операцией деления с остатком (%) #python #programming #hash #hashfunction #security #dataintegrity #optimization #pythonprogramming #hashing