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;
相关推荐
我喜欢就喜欢41 分钟前
基于离散余弦变换的感知哈希算法:原理、实现与工程实践
算法·哈希算法
cui_ruicheng5 小时前
C++数据结构进阶:哈希表实现
数据结构·c++·算法·哈希算法·散列表
童话ing1 天前
【Golang】Golang Map数据结构底层原理
数据结构·golang·哈希算法
handler011 天前
算法:字符串哈希
c语言·数据结构·c++·笔记·算法·哈希算法·散列表
cui_ruicheng1 天前
C++ 数据结构进阶:哈希表原理
数据结构·c++·算法·哈希算法
我星期八休息2 天前
深入理解哈希表
开发语言·数据结构·c++·算法·哈希算法·散列表
福楠2 天前
C++ | 哈希的应用
开发语言·c++·哈希算法
张李浩2 天前
Leetcode 454 四数相加II 采用哈希表解决
leetcode·哈希算法·散列表
月明长歌2 天前
【码道初阶-Hot100】LeetCode 560. 和为 K 的子数组:从前缀和到哈希计数,彻底讲透为什么“统计前缀和”就等价于统计子数组个数
算法·leetcode·哈希算法
Frostnova丶2 天前
(10)LeetCode 560. 和为K的子数组
算法·leetcode·哈希算法