169 похожих чатов

Правильно ли я понимаю, что в обычной реализации форта, без

хэширования, поиск слова в словаре с 100 записями может потребовать 100 сравнений слов? (И в среднем около 50)

3 ответов

13 просмотров

Без хэширования — да, перебираются все доствупные имена, или пока не найдется совпадение. Но, это простое сравнение на совпадение (без определения больше/меньше). Т.е., если длина разная — то сравнивать содержимое не надо. Что касается "обычности" — полно реализаций, которые используют хэширование в большей или меньшей мере.

ruv
Без хэширования — да, перебираются все доствупные ...

Кстати, тут я не прав, что если нет хэширования, то перебирается все имена. Т.к. можно еще хранить имена (ссылки) в упорядоченном массиве и делать бинарный поиск. А можно использовать сбалансированное дерево, и тоже искать в нем, без перебора всех вариантов. Т.е., хэширование — далеко не единственная альтернатива простому списку.

ruv
Кстати, тут я не прав, что если нет хэширования, т...

Технически, еще можно список переупорядочивать по частоте использования (чтобы наиболее частные были в голове списка). Во всех более сложных реализациях поиска надо специально обрабатывать случаи переопределения слова (когда в тот же список слов добавляется слово с именем, которое там уже было, и "затеняет" старое). В простом списке переопределение слова не требует специальной обработки.

Похожие вопросы

Обсуждают сегодня

@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Заметил в ghci 9.4.8: > :t (<*>) @((->)_) (<*>) @((->)_) :: (w -> (a -> b)) -> (w -> a) -> w -> b Разве не должно (w -> (a -> b)) быть записано как (w -> a -> b)? Это баг, ил...
Михаил
13
Any electron dev here?
Sayanth Tezro
12
Подобного рода ;Следующие три строки это директивы ассемблера, ;которые можно не задавать, т.к.работаем в Visual Studio. ;Символ ";" - это начало однострочного комментария ...
Егор Анелькин
3
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
так это может кто что знает или использует что-то как макбук только не макбук? на 13…14 дюймов
Michael
9
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
Кто-нибудь знает почему SPM клонирует репо целиком? Некоторые репы просто огромные, как та же swift-syntax которая нужна для использования макросов. Сначала подумал, что это...
iMike
6
Карта сайта