Sobes.tech
Назад к вопросам
Junior — Middle
66

Каким образом ты создаешь собственную реализацию словаря (dictionary)?

Компании, где спрашивали
KTS

Ответ от нейросети

sobes.tech AI

Для создания собственной реализации словаря (dictionary) в iOS на Swift можно использовать структуру данных на основе хэш-таблицы. Основная идея — хранить пары ключ-значение в массиве бакетов, где каждый бакет содержит список элементов с одинаковым хэш-кодом (для разрешения коллизий).

Пример простой реализации словаря с использованием массива и цепочек:

struct MyDictionary<Key: Hashable, Value> {
    private typealias Element = (key: Key, value: Value)
    private var buckets: [[Element]]
    private let capacity: Int

    init(capacity: Int = 16) {
        self.capacity = capacity
        self.buckets = Array(repeating: [], count: capacity)
    }

    private func index(forKey key: Key) -> Int {
        return abs(key.hashValue) % capacity
    }

    mutating func set(value: Value, forKey key: Key) {
        let index = self.index(forKey: key)
        // Проверяем, есть ли уже элемент с таким ключом
        if let i = buckets[index].firstIndex(where: { $0.key == key }) {
            buckets[index][i].value = value
        } else {
            buckets[index].append((key, value))
        }
    }

    func get(forKey key: Key) -> Value? {
        let index = self.index(forKey: key)
        return buckets[index].first(where: { $0.key == key })?.value
    }
}

// Использование:
var dict = MyDictionary<String, Int>()
dict.set(value: 42, forKey: "answer")
print(dict.get(forKey: "answer") ?? "not found")  // 42

Такой словарь поддерживает базовые операции вставки и поиска. Для продвинутой реализации можно добавить удаление, динамическое расширение, улучшенную обработку коллизий и т.д.