• hash 函数


    hash 函数

    #ifndef __SGI_STL_HASH_FUN_H
    #define __SGI_STL_HASH_FUN_H
    
    #include <stddef.h>
    
    __STL_BEGIN_NAMESPACE
    
    //@ hash function 是计算元素位置的函数
    //@ 这些函数可以对hashtable进行取模运算
    //@ 这是hashtable所提供的散列函数是取模运算决定的
    
    /*
    SGI hashtable以下有限的定义类型:
    	struct hash<char*>
    	struct hash<const char*>
    	struct hash<char> 
    	struct hash<unsigned char> 
    	struct hash<signed char>
    	struct hash<short>
    	struct hash<unsigned short> 
    	struct hash<int> 
    	struct hash<unsigned int>
    	struct hash<long> 
    	struct hash<unsigned long>
    不在这里定义的类型,不能使用,若用户想要使用,则必须自己定义。例如:string,double,float
    */
    
    
    template <class _Key> struct hash { };
    
    //@ 对const char* 提供字符串转换函数
    inline size_t __stl_hash_string(const char* __s)
    {
      unsigned long __h = 0; 
      for ( ; *__s; ++__s)
        __h = 5*__h + *__s;
      
      return size_t(__h);
    }
    
    __STL_TEMPLATE_NULL struct hash<char*>
    {
      size_t operator()(const char* __s) const { return __stl_hash_string(__s); }
    };
    
    __STL_TEMPLATE_NULL struct hash<const char*>
    {
      size_t operator()(const char* __s) const { return __stl_hash_string(__s); }
    };
    
    //@ 下面的hash函数都是直接返回原值
    //@ 对于char,unsigned char,signed char,int,unsigned int, 
    //@ short, unsigned short, long,unsigned long都只是返回数值本身
    __STL_TEMPLATE_NULL struct hash<char> {
      size_t operator()(char __x) const { return __x; }
    };
    __STL_TEMPLATE_NULL struct hash<unsigned char> {
      size_t operator()(unsigned char __x) const { return __x; }
    };
    __STL_TEMPLATE_NULL struct hash<signed char> {
      size_t operator()(unsigned char __x) const { return __x; }
    };
    __STL_TEMPLATE_NULL struct hash<short> {
      size_t operator()(short __x) const { return __x; }
    };
    __STL_TEMPLATE_NULL struct hash<unsigned short> {
      size_t operator()(unsigned short __x) const { return __x; }
    };
    __STL_TEMPLATE_NULL struct hash<int> {
      size_t operator()(int __x) const { return __x; }
    };
    __STL_TEMPLATE_NULL struct hash<unsigned int> {
      size_t operator()(unsigned int __x) const { return __x; }
    };
    __STL_TEMPLATE_NULL struct hash<long> {
      size_t operator()(long __x) const { return __x; }
    };
    __STL_TEMPLATE_NULL struct hash<unsigned long> {
      size_t operator()(unsigned long __x) const { return __x; }
    };
    
    __STL_END_NAMESPACE
    
    #endif /* __SGI_STL_HASH_FUN_H */
    

    总结

    • 在SGI STL中 hash 表的实现是采用拉链法,其中用到了哈希函数,哈希函数的作用是把元素键值映射到对应的桶子里面,一般哈希值是键值对桶子数取余。
    • 在 SGI STL提供的哈希函数是有限的,只支持特定的元素类型,若用户需要使用其他类型的哈希函数,则必须自行定义。定义的时候注意一下几点:
      • 使用 struct,然后重载 operator()。
      • 返回值是 size_t。
      • 参数是你要 hash 的 key 的类型。
      • 函数是const类型的。

    例如定义 string 类型的哈希函数:

    struct str_hash{
            size_t operator()(const string& str) const
            {
                    unsigned long __h = 0;
                    for (size_t i = 0 ; i < str.size() ; i ++)
                    __h = 5*__h + str[i];
                    return size_t(__h);
            }
    };
    
  • 相关阅读:
    Module not found: Error: Can't resolve './style':配置 extensions 的坑
    Mysql5.7前后修改用户密码变化
    一步步分析Java深拷贝的两种方式clone和序列化
    Windows下Nodejs的开发环境搭建
    JavaNIO第一话Buffer
    Vscode浏览器打开html vscode修改默认浏览器
    Windows电脑多个SSH Key管理.md
    jsonp跨域的原理
    POJ1502(MPI Maelstrom)
    POJ1088(滑雪)
  • 原文地址:https://www.cnblogs.com/xiaojianliu/p/12609103.html
Copyright © 2020-2023  润新知