Back to questions
Junior — Middle
67
Каким образом ты создаешь собственную реализацию словаря (dictionary)?
Companies where asked
KTS
Answer from AI
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
Такой словарь поддерживает базовые операции вставки и поиска. Для продвинутой реализации можно добавить удаление, динамическое расширение, улучшенную обработку коллизий и т.д.