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;
相关推荐
legend_jz9 小时前
STL--哈希
c++·算法·哈希算法
Dola_Pan20 小时前
C++算法和竞赛:哈希算法、动态规划DP算法、贪心算法、博弈算法
c++·算法·哈希算法
阿洵Rain21 小时前
【C++】哈希
数据结构·c++·算法·list·哈希算法
shenweihong1 天前
javascript实现国密hash(sm3)算法(支持微信小程序),可分多次计算
javascript·哈希算法
南城花随雪。1 天前
开放寻址法、链式哈希数据结构详细解读
数据结构·算法·哈希算法
南城花随雪。2 天前
哈希表(Hash Table)、跳表(Skip List) 和 有序字典(Ordered Dictionary) 的详细介绍
list·哈希算法·散列表
CCI3443 天前
详解Rust标准库:HashMap
rust·哈希算法·散列表
Wangx_wang4 天前
C++——unordered_map和unordered_set的封装
c++·哈希算法·散列表
fury_1235 天前
面试问题:hash和history的区别
面试·职场和发展·哈希算法
明月*清风5 天前
【力扣专题栏】字母异词分组,如何利用强大的容器(unordered_map)解决该问题?
leetcode·哈希算法·散列表