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;
相关推荐
huapiaoy6 小时前
Redis中数据类型的使用(hash和list)
redis·算法·哈希算法
luthane1 天前
python 实现djb2哈希算法
python·算法·哈希算法
曳渔2 天前
Java-数据结构-Map和Set(三)-习题 o(´^`)o
java·开发语言·数据结构·算法·leetcode·哈希算法
7yewh3 天前
C语言刷题 LeetCode 30天挑战 (七)哈希计数法
linux·c语言·c++·嵌入式硬件·算法·leetcode·哈希算法
前端 贾公子4 天前
Node.js 中使用 bcrypt 对密码进行哈希处理
算法·node.js·哈希算法
末代隐官-4 天前
贪心算法(4)
c++·算法·贪心算法·哈希算法
范特西元前6 天前
【数据结构中的哈希】
数据结构·算法·哈希算法
曳渔7 天前
Java-数据结构-Map和Set-(二)-哈希表 |ू・ω・` )
java·开发语言·数据结构·算法·哈希算法·散列表
娇娇yyyyyy7 天前
异或哈希(求区间内所有的数的出现的次数是否为偶数)
算法·哈希算法
谢尔登8 天前
【Webpack】Hash 码
算法·webpack·哈希算法