X-Authentication-Warning: anthony.siemens.ebp.ii3.b-rail.be: ddemerre owned process doing -bs
Date: Fri, 2 Feb 2001 06:23:29 +0100 (CET)
From: Dieter Demerre <ext DOT dieter DOT demerre AT siemens DOT be>
X-Sender:  <ddemerre AT anthony DOT siemens DOT ebp DOT ii3 DOT b-rail DOT be>
To: <djgpp AT delorie DOT com>
Subject: Re: Hash function
In-Reply-To: <95cfee$m9h$1@venus.telepac.pt>
Message-ID: <Pine.LNX.4.30.0102020622480.28137-100000@anthony.siemens.ebp.ii3.b-rail.be>
MIME-Version: 1.0
Content-Type: TEXT/PLAIN; charset=X-UNKNOWN
Content-Transfer-Encoding: 8bit
X-MIME-Autoconverted: from QUOTED-PRINTABLE to 8bit by delorie.com id AAA32655
Reply-To: djgpp AT delorie DOT com
Errors-To: nobody AT delorie DOT com
X-Mailing-List: djgpp AT delorie DOT com
X-Unsubscribes-To: listserv AT delorie DOT com
Precedence: bulk

-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1

On Thu, 1 Feb 2001, Frederico Jer�nimo wrote:

>     Ex : Given 0x8ae29 the function would return 0x629
>
>     I know this is not a very efficient hash function so I was wondering if
> anyone has any ideas for a better one. Thanks in advance,

int hashpjw(const int seed, const char* s)
/*
  ACTION:
    perform some bit-operations upon the characters of s, to obtain a
    rather unique integer.  (chaotic behaviour)
    (n.b. chaotic means little changes within s chould cause huge changes
    in result)
    Refer to the Dragonbook.
 */
{
  const char* p;
  unsigned int hv = 0;
  unsigned int g;

  for ( p = s; *p; p++ ) {
    hv = (hv << 4) + (*p);
    if ((g = (hv & 0xf0000000U)) != 0U) {
      hv = hv ^ (g >> 24);
      hv = hv ^ g;
    } else {
    }
  }
  return hv % seed;
}


- -- Groetjes vanwege... Greetings from... --
- -- Dieter Demerre  ***  ddemerre AT acm DOT org --
- -- http://www.angelfire.com/de/ddemerre/ --

-----BEGIN PGP SIGNATURE-----
Version: PGP 6.5.8

iQA/AwUBOnpEWglG34XnM6kpEQKgPgCfXOGpwglZWcBMHjbzQBLcmrEoQQgAoNtp
G74fNBxbmrf2Aff0suJx9p0f
=jkYA
-----END PGP SIGNATURE-----