1. Заголовок или название темы должно быть информативным !
2. Все тексты фрагментов программ должны помещаться в теги [code] ... [/code] или [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ" и используйте ПОИСК !
4. НЕ используйте форум для личного общения!
5. Самое главное - это раздел теоретический, т.е. никаких задач и программ (за исключением небольших фрагментов) - для этого есть отдельный раздел!
| a3boot |
22.03.2007 17:58
Сообщение
#1
|
|
Группа: Пользователи Сообщений: 5 Пол: Мужской Репутация: 0 |
Всё ещё занимаюсь поиском в таблице служебных слов...
--- Пока что я пользуюсь чем-то подобным trunc(a*(ord(s[1]))+b*(ord(s[length(s)])))-k Такая функция не имеет коллизий, занимает не много памяти (134 ячейки на 34 слова), но, как мне кажется работает медленно. --- Может, кто сталкивался с разработкой хэш - функций для строк и готов поделиться опытом. Таблица слов известна (см. table.txt) Прикрепленные файлы
table.txt ( 204 байт )
Кол-во скачиваний: 219 |
![]() ![]() |
| a3boot |
22.03.2007 22:09
Сообщение
#2
|
|
Группа: Пользователи Сообщений: 5 Пол: Мужской Репутация: 0 |
Я, наверно, не корректно высказался по поводу ячеек.
--- Под ячейкой в данном случае понимается один элемент массива служебных слов. --- Наверно, лучше говорить о множестве значений хэш-функции. Предложеная функция (o - 65) shl 3 xor pпринимает значения от 6 до 248 следовательно для хранения такой таблицы требуется 243 ячейки ([6..242]). Моя функция давала значения от 0 до 133 - 134 ячейки, но она проигрывает по времени выше указанной. --- Время для меня в данный момент является более важной характеристикой, поэтому Огромное спасибо Malice!!! Может быть предложишь ещё какие - нибудь хэши, а я поэкспериментирую... |
| Malice |
23.03.2007 0:54
Сообщение
#3
|
![]() Профи ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 705 Пол: Мужской Репутация: 20 |
|
a3boot Хэш - функция для строк 22.03.2007 17:58
Malice
занимает не много памяти (134 ячейки на 34 слова)... 22.03.2007 20:20
a3boot Malice, спасибо за помощь.
---
У меня ещё вопрос :... 25.03.2007 15:31
Malice Только 1-го и 2-го нельзя, т.к. они повторяются в ... 25.03.2007 18:50![]() ![]() |
|
Текстовая версия | 10.12.2025 16:15 |