青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

無我

讓內心永遠燃燒著偉大的光明的精神之火!
靈活的思考,嚴謹的實現
豪邁的氣魄、頑強的意志和周全的思考

hash函數——djb2、sdbm、lose lose

本文內容轉自于http://www.cse.yorku.ca/~oz/hash.html。因為他對給出了幾個非常好的hash函數,而其中的sdbm就是我們將剖析的eSNACC用的hash的原型。文章是英文的,但是通俗易懂,就摘錄在此了。

 

Hash Functions

A comprehensive collection of hash functions, a hash visualiser and some test results [see Mckenzie et al. Selecting a Hashing Algorithm, SP&E 20(2):209-224, Feb 1990] will be available someday. If you just want to have a good hash function, and cannot wait, djb2 is one of the best string hash functions i know. it has excellent distribution and speed on many different sets of keys and table sizes. you are not likely to do better with one of the "well known" functions such as PJW, K&R[1], etc. Also see tpop pp. 126 for graphing hash functions.


 

djb2

this algorithm (k=33) was first reported by dan bernstein many years ago in comp.lang.c. another version of this algorithm (now favored by bernstein) uses xor: hash(i) = hash(i - 1) * 33 ^ str[i]; the magic of number 33 (why it works better than many other constants, prime or not) has never been adequately explained.

    unsigned long
    hash(unsigned char *str)
    {
        unsigned long hash = 5381;
        int c;

        while (c = *str++)
            hash = ((hash << 5) + hash) + c; /* hash * 33 + c */

        return hash;
    }


 

sdbm

this algorithm was created for sdbm (a public-domain reimplementation of ndbm) database library. it was found to do well in scrambling bits, causing better distribution of the keys and fewer splits. it also happens to be a good general hashing function with good distribution. the actual function is hash(i) = hash(i - 1) * 65599 + str[i]; what is included below is the faster version used in gawk. [there is even a faster, duff-device version] the magic constant 65599 was picked out of thin air while experimenting with different constants, and turns out to be a prime. this is one of the algorithms used in berkeley db (see sleepycat) and elsewhere.

    static unsigned long
    sdbm(str)
    unsigned char *str;
    {
        unsigned long hash = 0;
        int c;

        while (c = *str++)
            hash = c + (hash << 6) + (hash << 16) - hash;

        return hash;
    }

lose lose

This hash function appeared in K&R (1st ed) but at least the reader was warned: "This is not the best possible algorithm, but it has the merit of extreme simplicity." This is an understatement; It is a terrible hashing algorithm, and it could have been much better without sacrificing its "extreme simplicity." [see the second edition!] Many C programmers use this function without actually testing it, or checking something like Knuth's Sorting and Searching, so it stuck. It is now found mixed with otherwise respectable code, eg. cnews. sigh. [see also: tpop]

    unsigned long
    hash(unsigned char *str)
    {
	unsigned int hash = 0;
	int c;

	while (c = *str++)
	    hash += c;

	return hash;
    }

 

 

posted on 2012-04-26 08:52 Tim 閱讀(2681) 評論(1)  編輯 收藏 引用 所屬分類: C/C++語言

評論

# re: hash函數——djb2、sdbm、lose lose[未登錄] 2012-04-27 09:35 Tina

頂!  回復  更多評論   

<2012年4月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345

導航

統計

公告

本博客原創文章,歡迎轉載和交流。不過請注明以下信息:
作者:TimWu
郵箱:timfly@yeah.net
來源:www.shnenglu.com/Tim
感謝您對我的支持!

留言簿(9)

隨筆分類(173)

IT

Life

搜索

積分與排名

最新隨筆

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲视频在线观看三级| 亚洲欧洲精品一区二区三区 | 这里只有精品丝袜| 欧美精品乱人伦久久久久久| 亚洲国产合集| 欧美激情一区在线观看| 欧美成人影音| 夜夜嗨av一区二区三区四区| 一区二区三区不卡视频在线观看| 欧美午夜电影网| 亚洲综合电影一区二区三区| 中文在线不卡| 国产色爱av资源综合区| 蜜臀av在线播放一区二区三区| 久久综合中文色婷婷| 91久久夜色精品国产九色| 最新热久久免费视频| 欧美精品一区二区三| 亚洲免费在线| 久久久久成人精品| 中日韩视频在线观看| 香蕉久久夜色精品| 亚洲青色在线| 亚洲欧美日本视频在线观看| 国内外成人在线视频| 亚洲国产福利在线| 国产欧美精品在线观看| 美日韩精品免费| 欧美日韩一区二| 久久久91精品| 欧美日韩精品福利| 久久久另类综合| 欧美日本韩国一区| 久久精品视频在线观看| 欧美精品电影| 久久另类ts人妖一区二区| 欧美国产激情| 久久先锋资源| 欧美日韩在线电影| 欧美大秀在线观看| 国产精品欧美久久| 亚洲国产精品专区久久| 亚洲日本va午夜在线影院| 国产精品久久久久久久久久妞妞| 久久午夜精品一区二区| 欧美色视频一区| 欧美aa在线视频| 国产亚洲精品bt天堂精选| 亚洲精品少妇网址| 欧美日韩福利视频| 久久综合伊人77777蜜臀| 欧美天堂在线观看| 亚洲国产精品小视频| 国产亚洲欧美激情| 亚洲视频第一页| 日韩午夜在线| 欧美成人自拍视频| 欧美激情小视频| 国内精品久久久久久久果冻传媒| 一区二区黄色| 99热免费精品| 欧美风情在线| 美女福利精品视频| 精品91在线| 欧美一区免费视频| 久久精彩免费视频| 国产精品一区免费观看| 亚洲午夜视频| 午夜精品久久久久影视| 国产精品chinese| 一区二区日韩伦理片| 亚洲视频精品在线| 欧美视频一区二区三区在线观看| 亚洲国产精品视频一区| 91久久精品一区二区三区| 久久久久免费视频| 欧美成人中文字幕| 亚洲激情黄色| 欧美精品网站| 亚洲深爱激情| 欧美在线短视频| 国产一区视频观看| 久久在线91| 亚洲精选91| 亚洲摸下面视频| 国产精品多人| 香蕉成人久久| 免费av成人在线| 日韩视频国产视频| 欧美偷拍一区二区| 午夜欧美不卡精品aaaaa| 久久免费精品日本久久中文字幕| 一区二区在线看| 欧美激情综合网| 99亚洲视频| 久久久久一本一区二区青青蜜月| 亚洲国产精品久久久久秋霞蜜臀| 欧美大片一区二区三区| 洋洋av久久久久久久一区| 欧美在线观看视频在线| 黄色日韩网站| 欧美日本在线观看| 欧美一区二区日韩一区二区| 免费看精品久久片| 亚洲特级毛片| 激情欧美一区二区三区| 欧美日本亚洲韩国国产| 午夜激情一区| 亚洲精品美女久久久久| 欧美一区二区三区在线播放| 亚洲欧洲另类| 国产色综合天天综合网| 欧美电影在线观看| 亚洲欧美综合另类中字| 91久久久精品| 久久久久久久综合狠狠综合| 一本一道久久综合狠狠老精东影业 | 亚洲日本电影| 久久久国产精品亚洲一区 | 国产一区二区三区四区老人| 欧美福利影院| 久久xxxx精品视频| 一本久道久久综合狠狠爱| 噜噜爱69成人精品| 性欧美精品高清| 一区二区福利| 亚洲国产黄色片| 国产欧美在线| 国产精品美女主播| 欧美精品激情在线| 久久精品中文字幕一区| 亚洲一区三区视频在线观看| 欧美黄网免费在线观看| 久久不射中文字幕| 亚洲主播在线| 一区二区三区久久| 亚洲黄色免费电影| 狠狠色伊人亚洲综合成人| 国产精品久久91| 欧美日韩中文字幕在线| 欧美国产第一页| 乱中年女人伦av一区二区| 欧美亚洲免费高清在线观看| 在线综合视频| 一区二区三区四区五区在线| 亚洲精品国产精品国产自| 欧美xart系列在线观看| 久久青青草综合| 久久久999国产| 久久精品导航| 久久国产精品久久久久久| 亚洲一区在线播放| 亚洲一区二区三区免费视频| 国产精品剧情在线亚洲| 欧美日韩一级视频| 欧美天堂在线观看| 国产精品另类一区| 国产日产欧美一区| 韩日欧美一区二区三区| 狠狠爱www人成狠狠爱综合网| 激情成人在线视频| 在线精品观看| 亚洲破处大片| 一区二区三区av| 午夜精品亚洲| 久久精品国产在热久久 | 在线日韩av永久免费观看| 在线精品视频在线观看高清| 亚洲国产日韩欧美| 一区二区三区欧美在线| 亚洲欧美日韩视频一区| 久久精品国产在热久久| 久热精品视频在线观看| 亚洲国产美国国产综合一区二区| 亚洲免费成人av电影| 亚洲欧美日韩精品久久久| 久久久夜精品| 欧美日韩在线不卡| 国语自产在线不卡| 亚洲人成网站在线观看播放| 中文精品视频| 久久人体大胆视频| 亚洲精品女人| 在线一区二区三区四区| 欧美在线电影| 欧美极品影院| 国产亚洲欧洲997久久综合| 亚洲国产另类精品专区| 亚洲女人小视频在线观看| 久久人人爽人人| 亚洲免费成人av| 久久精品91久久香蕉加勒比| 欧美精品久久久久久久| 国产欧美日韩另类一区| 亚洲肉体裸体xxxx137| 性欧美精品高清| 亚洲乱码精品一二三四区日韩在线| 欧美一区二区观看视频| 欧美日韩亚洲三区| 亚洲福利久久|