Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 5.00/9: Рейтинг темы: голосов - 9, средняя оценка - 5.00
 Аватар для AzaKendler
214 / 116 / 14
Регистрация: 30.05.2011
Сообщений: 1,772
Записей в блоге: 15

растолкуйте про хэш плиз

23.08.2011, 13:33. Показов 1997. Ответов 22
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
на картинке реализация поиска в "hash_map" от Страуструпа. И все бы хорошо если бы не один момент.
b и v это векторы. И доступ по индексу в векторе [] ассоциируется у меня с чем то упорядоченным, например [0], [5] и тд. а строка
C++
1
set_type i = hash(K)%b.size()
- какое значение дает i? можно ли гарантировать применив остаток от деления hash(k) на размер вектора, в качестве индекса, что мы не выйдем за пределы вектора в какую либо сторону?
Миниатюры
растолкуйте про хэш плиз  
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
23.08.2011, 13:33
Ответы с готовыми решениями:

Растолкуйте про биос!
материнская плата MSI MS-7519 ver 1.2 P43 NEO процессор E8400 решил помучать свой проц,и чуток его погонять по частотам.Штатная частота...

Проясните про апы,плиз!
Правильно ли я понимаю,что существуют апдейт выдачи сайта по позициям и апдейт ТИЦа? Они происходят с какой-то переодичностью? Можно ли...

Подскажите плиз про Директ
Сайт взяли в Яндекс.Директ. Написали мне, что я могу работать с Директом как: 1. Напрямую как физлицо 2. Напрямую как юрлицо 3. Как...

22
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
23.08.2011, 14:36
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от AzaKendler Посмотреть сообщение
Т.е. в данном конкретном случае гарантия уже есть. это тип переменной.
Но в общем случае полагаться на остаток от деления нельзя.
ТАК?
Представим такой случай:
C++
1
vec[hash % v.size()] = 0;
Если переменная hash имеет беззнаковый тип, то гарантия есть. Если знаковый, то придется вставить дополнительную проверку. И, например, сделать вот так:
C++
1
vec[abs(hash) % v.size()] = 0;
Но, к слову говоря, хэш это как правило положительное число и хранить хэш в знаковом типе уже неправильно.
1
 Аватар для AzaKendler
214 / 116 / 14
Регистрация: 30.05.2011
Сообщений: 1,772
Записей в блоге: 15
23.08.2011, 14:41  [ТС]
fasked, а в чем лучше хранить хэш, понимаю что про это надо отдельно читать и есть много инфы. но раз уж...

Добавлено через 1 минуту
Цитата Сообщение от AzaKendler Посмотреть сообщение
set_type
во блин написал.
0
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
23.08.2011, 14:43
ForEveR, ну и пусть не соглашается, за пределы все равно не выйдет
а в чем лучше хранить хэш, понимаю что про это надо отдельно читать и есть много инфы. но раз уж...
Все зависит от функции, которая вычисляет хэш. Чаще всего хэш - это 32-битное значение, то есть подойдет unsigned int.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
23.08.2011, 14:43
Помогаю со студенческими работами здесь

Поясните про перекрестный обмен плиз...
Господа, есть вопрос про перекрестный обмен... Есть два сайта: Сайт А - Авто PR3, ТИЦ10 (не погонялся никогда) Сайт B - Авто...

Подскажите плиз про локальную политику безопасности Windows serv 2008
Добрый день уважаемые форумчане. Решил попробовать поставить Windows server 2008. В двух словах нужно поменять локальную политику...

Описать класс "хэш-таблица", используя unordered_set и заданную хэш-функцию
Здравствуйте. Есть класс объектов и ключ сравнения: #pragma once #include <iostream> #include <vector> #include <list>...

растолкуйте
наткнулся на статью http://www.runetpoisk.ru/ и там написано: Это правда или очередная сказка?

Растолкуйте бсод
Впервые за пол года вылетел бсод, аж интересно почему. Скриншот из BSView: Добавлено через 6 минут Увидел что виноват USB драйвер,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
23
Ответ Создать тему
Новые блоги и статьи
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru