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;
相关推荐
Watermelo6178 小时前
【前端实战】如何让用户回到上次阅读的位置?
前端·javascript·性能优化·数据分析·哈希算法·哈希·用户体验
John Song1 天前
Redis 集群批量删除key报错 CROSSSLOT Keys in request don‘t hash to the same slot
数据库·redis·哈希算法
Zfox_2 天前
Redis:Hash数据类型
服务器·数据库·redis·缓存·微服务·哈希算法
补三补四3 天前
哈希(Hash)
哈希算法
张哈大3 天前
【 java 集合知识 第二篇 】
java·开发语言·笔记·哈希算法
这儿有一堆花3 天前
比特币:固若金汤的数字堡垒与它的四道防线
算法·区块链·哈希算法
枣伊吕波4 天前
第十三节:第四部分:集合框架:HashMap、LinkedHashMap、TreeMap
java·哈希算法
小河豚oO4 天前
LeetCode 热题 100 - 哈希 - 128
算法·leetcode·哈希算法
客卿1234 天前
力扣100题之128. 最长连续序列
算法·leetcode·哈希算法
YuTaoShao5 天前
HashMap中的put方法执行流程(流程图)
流程图·哈希算法·散列表