![]() |
1. Заголовок или название темы должно быть информативным !
2. Все тексты фрагментов программ должны помещаться в теги [code] ... [/code] или [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ" и используйте ПОИСК !
4. НЕ используйте форум для личного общения!
5. Самое главное - это раздел теоретический, т.е. никаких задач и программ (за исключением небольших фрагментов) - для этого есть отдельный раздел!
![]() |
a3boot |
![]()
Сообщение
#1
|
Группа: Пользователи Сообщений: 5 Пол: Мужской Репутация: ![]() ![]() ![]() |
Всё ещё занимаюсь поиском в таблице служебных слов...
--- Пока что я пользуюсь чем-то подобным trunc(a*(ord(s[1]))+b*(ord(s[length(s)])))-k Такая функция не имеет коллизий, занимает не много памяти (134 ячейки на 34 слова), но, как мне кажется работает медленно. --- Может, кто сталкивался с разработкой хэш - функций для строк и готов поделиться опытом. Таблица слов известна (см. table.txt) Прикрепленные файлы ![]() |
![]() ![]() |
Malice |
![]()
Сообщение
#2
|
![]() Профи ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 705 Пол: Мужской Репутация: ![]() ![]() ![]() |
занимает не много памяти (134 ячейки на 34 слова) Не понял, как такое могло получится.. Если у тебя комбинация 2-х символов уникальна, то для хеша одной строки надо 2 байта максимум. Пусть: o=ord(s[1]); p=ord(s[length(s)]); Хеш=o shl 8+p; (от умножений лучше избавиться, т.к медленнно это). В твоем случае можно и в 1 байт засунуть, просто подогнать, вот так например: Хеш=(o-65) shl 3 xor p; Тоже уникально получится.. Если строки любые, то такие методы не пройдут, нужно каждый символ в строке учитывать. |
![]() ![]() |
![]() |
Текстовая версия | 16.08.2025 20:03 |