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

Друзья, а когда перезагружаешь хэш-функцию, например, так: struct PairHash {

size_t operator()(const pair<int, int> p) const { // передавать pair<int, int> по ссылке или нет?

return (size_t)(h_i_1(p.first) * 37 * 37 + h_i_1(p.second) * 37 + 117);
}
hash<int> h_i_1;
hash<int> h_i_2;
};

То надо для каждого аргумента переопределять hash<int> :
hash<int> h_i_1;
hash<int> h_i_2;

или можно использовать нечто такое:

struct PairHash {
size_t operator()(const pair<int, int> p) const { // передавать pair<int, int> по ссылке или нет?

return (size_t)(h(p.first) * 37 * 37 + h(p.second) * 37 + 117);
}
hash<int> h;
};


и почему надо именно так?

2 ответов

7 просмотров

Бессмысленно делать так, как в первом примере, так как h_i_1 и h_i_2 представляют собой объекты, реализующие хэш-функцию и к ним предъявлено требование: Результат hash<T>{}(t), где t имеет тип T должен зависеть только от значения t То есть, неважно, как ты напишешь: h(p.first), h_i_1(p.first), h_i_2(p.first) — везде результат будет одинаковый, и зачем тогда плодить лишние переменные.

Eoan Ermine
Бессмысленно делать так, как в первом примере, так...

И еще, кстати, прикольчик вдовесок. hash<int>, по крайней мере в libc++, определен следующим образом: struct hash<int> { size_t operator()(int __v) const { return static_cast<size_t>(__v); } } :)

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

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

@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Подобного рода ;Следующие три строки это директивы ассемблера, ;которые можно не задавать, т.к.работаем в Visual Studio. ;Символ ";" - это начало однострочного комментария ...
Егор Анелькин
3
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
еще вопрос, допустим мы создадим char массив из 10 элементов и присвоим ему через сканф 10 символов. и выведем все символы. Хотел спросить последний элемент /0 будет включать...
Anthem
10
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
открыть папку в проводнике: 1 - ShellExecute 2 - ExecuteProcess 3 - OpenDocument что лучше выбрать?
Alexey Kulakov
12
Изменение типа с SomeException на String и правда удобней @cheese_hs . А вот такой вариант насколько некрасив еще? loadConfigDB :: IO (Either String ConfigDataBase) loadConfi...
Camara
7
Где в Астане можно купить мясо для шашлыков?
Dancing Іңұқәһүғө
21
Карта сайта