pair作为unordered_map的key报错

问题

pair作为unordered_map的key报错,编译时会报错

原因

因为pair没有哈希函数

解决方法

定义哈希函数

cpp 复制代码
template <typename T>
inline void hash_combine(std::size_t &seed, const T &val) {
    seed ^= std::hash<T>()(val) + 0x9e3779b9 + (seed << 6) + (seed >> 2);
}
// auxiliary generic functions to create a hash value using a seed
template <typename T> inline void hash_val(std::size_t &seed, const T &val) {
    hash_combine(seed, val);
}
template <typename T, typename... Types>
inline void hash_val(std::size_t &seed, const T &val, const Types &... args) {
    hash_combine(seed, val);
    hash_val(seed, args...);
}

template <typename... Types>
inline std::size_t hash_val(const Types &... args) {
    std::size_t seed = 0;
    hash_val(seed, args...);
    return seed;
}

struct pair_hash {
    template <class T1, class T2>
    std::size_t operator()(const std::pair<T1, T2> &p) const {
        return hash_val(p.first, p.second);
    }
};

使用

cpp 复制代码
unordered_map<pair<long long, long long>, long long, pair_hash> slopeCount;
相关推荐
沉默-_-10 小时前
备战蓝桥杯-哈希
c++·学习·算法·蓝桥杯·哈希算法
AI人工智能+电脑小能手11 小时前
【大白话说Java面试题】【Java基础篇】第19题:HashMap的key如何减少发生哈希冲突
java·开发语言·后端·面试·哈希算法·hash-index·hash
shehuiyuelaiyuehao12 小时前
算法13,滑动窗口,水果成篮
算法·哈希算法·散列表
样例过了就是过了13 小时前
LeetCode热题100 单词拆分
c++·算法·leetcode·动态规划·哈希算法
AI人工智能+电脑小能手1 天前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
睡觉就不困鸭1 天前
第十七天 翻转字符串里的单词
数据结构·算法·哈希算法·散列表
AI人工智能+电脑小能手2 天前
【大白话说Java面试题】【Java基础篇】第17题:HashMap的加载因子为什么是0.75而不是1或0.5
java·开发语言·算法·哈希算法·散列表
谭欣辰2 天前
C++ 哈希表详解
c++·算法·哈希算法·散列表
|_⊙2 天前
C++ 哈希
算法·哈希算法·散列表
无籽西瓜a2 天前
MD5算法原理、适用场景
java·后端·算法·哈希算法·md5