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;
相关推荐
joker D8881 天前
【C++】深入理解 unordered 容器、布隆过滤器与分布式一致性哈希
c++·分布式·哈希算法
XiaoyaoCarter2 天前
每日一道leetcode(新学数据结构版)
数据结构·c++·算法·leetcode·职场和发展·哈希算法·前缀树
٩( 'ω' )و2603 天前
哈希表的实现01
数据结构·c++·哈希算法·散列表
学习中的码虫3 天前
c 中的哈希表
数据结构·哈希算法·散列表
Wythzhfrey5 天前
单片机Day10
单片机·嵌入式硬件·哈希算法
寒士obj7 天前
HashMap中put()方法的执行流程
java·哈希算法·散列表
千里镜宵烛7 天前
C++ 哈希表
开发语言·数据结构·c++·哈希算法·散列表
James. 常德 student7 天前
leetcode-hot-100(哈希)
算法·leetcode·哈希算法
Codeking__10 天前
滑动窗口——无重复字符最长的字串
算法·哈希算法
小wanga11 天前
【算法专题十】哈希表
算法·哈希算法·散列表