一些字符串哈希算法

作者: 客昂康 | 来源:发表于2019-02-23 15:22 被阅读23375次

见代码:

unsigned int hash_BPHash(unsigned char *str){
    unsigned int hash = 0;
    while(*str){
        hash = (hash << 7) ^ (*str++);
    }
    return hash;
}

unsigned int hash_FNVHash(unsigned char *str){
    unsigned int hash = 0;
    while(*str){
        hash = (hash * 0x811C9DC5) ^ (*str++);
    }
    return hash;
}

unsigned int hash_BKDRHash(unsigned char *str){
    unsigned int hash = 0;
    while(*str){
        hash = (hash * 131) + (*str++); // 31 131 1313 13131 131313 etc...
    }
    return hash;
}

unsigned int hash_DJBHash(unsigned char *str){
    unsigned int hash = 5381;
    while(*str){
        hash += ((hash << 5) + (*str++));
    }
    return hash;
}

unsigned int hash_JSHash(unsigned char *str){
    unsigned int hash = 1315423911;
    while(*str){
        hash ^= ((hash << 5) + (hash >> 2) + (*str++));
    }
    return hash;
}

unsigned int hash_DEKHash(unsigned char *str){
    unsigned int hash = strlen(str);
    while(*str){
        hash = ((hash << 5) ^ (hash >> 27)) ^ (*str++);
    }
    return hash;
}

unsigned int hash_SDBMHash(unsigned char *str){
    unsigned int hash = 0;
    while(*str){
        hash = (hash << 6) + (hash << 16) + (*str++) - hash;
    }
    return hash;
}

unsigned int hash_RSHash(unsigned char *str){
    unsigned int a = 63689;
    unsigned int hash = 0;
    while(*str){
        hash = hash * a + (*str++);
        a *= 378551;
    }
    return hash;
}

unsigned int hash_APHash(unsigned char *str){
    unsigned int hash = 0;   //0x00000000, 0xAAAAAAAA
    unsigned int flag = 0;
    while(*str){
        if(flag&1){
            hash ^= (~((hash << 11) ^ (*str++) ^ (hash >> 5)));
        }
        else{
            hash ^= ((hash << 7) ^ (*str++) ^ (hash >> 3));
        }
        flag++;
    }
    return hash;
}

unsigned int hash_PJWHash(unsigned char *str){
    unsigned int hash = 0;
    unsigned int test = 0;
    while(*str){
        hash = (hash << 4) + (*str++);
        if((test = hash & 0xF0000000) != 0){
            hash = ((hash ^ (test >> 24)) & 0x0FFFFFFF);
        }
    }
    return hash;
}

unsigned int hash_ELFHash(unsigned char *str){
    unsigned int hash = 0;
    unsigned int test = 0;
    while(*str){
        hash = (hash << 4) + (*str++);
        if((test = hash & 0xF0000000) != 0){
            hash = ((hash ^ (test >> 24)) & (~test));
        }
    }
    return hash;
}

另外收集了一个查表法的CRC32校验算法,也可用于字符串哈希,见 《一种查表法实现的CRC32校验算法》 这篇笔记。
记于 2019-02-23

相关文章

  • 感知哈希算法

    感知哈希算法是一类哈希算法的总称,其作用在于生成每张图像的“指纹”(fingerprint)字符串,比较不同图像的...

  • 一些字符串哈希算法

    见代码: 另外收集了一个查表法的CRC32校验算法,也可用于字符串哈希,见 《一种查表法实现的CRC32校验算法》...

  • 哈希算法

    1.定义 哈希算法是加密算法,它的特点是可以将任意长度的信息转换成一段固定长度的字符串。哈希值是通过哈希运算从而映...

  • mysql---索引优化

    一 索引概念 索引就是为特定的mysql字段进行一些特定的算法排序,比如二叉树的算法和哈希算法,哈希算法是通过建立...

  • MySQL索引优化

    概述 索引就是为特定的mysql字段进行一些算法排序,比如二叉树算法和哈希算法,哈希算法是通过简历特征值,然后根据...

  • 区块基础知识

    哈希算法的本质: 哈希函数输入可以是任意长的字符串函数输出是固定长度的函数计算过程具有一定的效率 为保障哈希函数的...

  • struct

    sds结构sds主要是用来存储字符串 空间预分配 删除空间 链表 链表里面封装了一个迭代器 字典 哈希算法 哈希冲...

  • iOS-RSA2加签、验签

    私钥加密: 1.使用哈希算法获取待签名字符串的摘要 2.使用私钥字符串获取SecKeyRef指针,通过读取pem文...

  • 算法系列:5分钟了解哈希算法

    前言 哈希算法是现代密码体系中的一个重要组成部分。大家比较感兴趣的数字货币,就使用了哈希算法。 哈希算法简介 哈希...

  • 加密算法 MD5 AES

    MD5全称为信息-摘要算法(哈希算法) MD5是一种单向加密,它的加密不可逆,它将任意长度的字符串,经过算法计算后...

网友评论

    本文标题:一些字符串哈希算法

    本文链接:https://www.haomeiwen.com/subject/uprpyqtx.html