int ELFhash ( char *key ) {
unsigned long h=0;
unsigned long x=0;
while (*key ) {
//h左移4位,当前字符ASCII存入h的低四位
h = ( h << 4 ) + ( *key++ );
if ( ( x = h & 0xF0000000L) != 0 ) {
//如果最高位不为0,则说明字符多余7个,如果不处理,再加第九个字符时,第一个字符会被移出,因此要有如下处理
h ^= ( x >> 24 );
//清空28~31位
h &= ~x;
}
}
return h % N;
}
ELFhash——字符串Hash函数
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
相关阅读更多精彩内容
- 只有指针是可以运算(移动)的,数组名是不可以的。 int x[10]; x++; //illegal int* ...