散列函数 HashPJW and ElfHash

本文对比介绍了两种散列函数:HashPJW与ElfHash。HashPJW通过位移和按位或操作来实现散列,而ElfHash则利用左移和异或运算。这两种方法均可用于字符串散列,但在不同场景下表现各异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一个通用的散列函数 HashPJW要比ElfHash要好一点,但也要看具体情况,

/× HashPJW8*/
#include <limits.h>

#define BITS_IN_int (sizeof (int) * CHAR_BIT)
#define THREE_QUARTERS ((int) ((BITS_IN_int * 3) / 4))
#define ONE_EIGHTH ((int) (BITS_IN_int / 8 ))
#define HIGH_BITS ( ~((unsighed int)(~0) >> ONE_EIGHTH ))

unsigned int HashPJW ( const char * datum )
{
unsigned int hash_value, i;

for ( hash_value = 0; *datum; ++datum)
{
hash_value = ( hash_value << ONE_EIGHTH ) + *datum;
if (( i = hash_value & HIGH_BITS ) !=0 )
hash_value =
( hash_value ^ ( i>> THREE_QUARTERS )) &
~HIGH_BITS;
}
return ( hash_value );
}

/* ElfHash */

unsighed long ElfHash ( const unsigned char *name)
{
unsigned long h = 0, g;
while ( *name )
{
h = ( h << 4 ) + *name++;
if ( g = h & 0xF0000000 )
h ^= g >> 24;
h &= ~g;
}
return h;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值