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

無我

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

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 閱讀(2666) 評論(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>
            国产精品99免费看 | 欧美激情第10页| 久久久国际精品| 亚洲国产精品99久久久久久久久| 美女脱光内衣内裤视频久久网站| 老牛影视一区二区三区| 亚洲国产欧美日韩精品| 亚洲国产美女| 欧美日韩影院| 久久精品伊人| 欧美韩日精品| 欧美在线视频一区| 久久亚洲国产精品一区二区| 亚洲人成亚洲人成在线观看| 99精品免费网| 在线播放国产一区中文字幕剧情欧美 | 国产精品一区二区三区观看| 久久精品视频va| 欧美二区不卡| 欧美在线免费观看视频| 麻豆av福利av久久av| 亚洲视频大全| 久久人体大胆视频| 亚洲欧美精品在线| 另类成人小视频在线| 亚洲欧美日韩精品一区二区| 久热精品在线| 欧美中文在线观看| 欧美女人交a| 久久女同互慰一区二区三区| 欧美精品在线视频| 久久夜色精品国产欧美乱极品| 欧美日韩八区| 欧美电影免费观看高清| 国产日韩精品在线| 亚洲巨乳在线| 最新日韩在线视频| 久久成年人视频| 亚洲一区3d动漫同人无遮挡| 久色婷婷小香蕉久久| 久久国产加勒比精品无码| 欧美精品国产| 亚洲大胆女人| 激情久久久久| 久久黄色网页| 欧美专区在线观看| 国产精品手机视频| 夜夜嗨av一区二区三区四季av| 亚洲黄一区二区| 久久精品视频在线看| 欧美一区二区在线免费观看 | 亚洲欧美日韩精品一区二区| 99综合在线| 欧美激情一区二区三区在线视频| 裸体丰满少妇做受久久99精品| 国产欧美日韩亚洲精品| 亚洲一卡二卡三卡四卡五卡| 亚洲一区二区伦理| 欧美三级在线视频| 一区二区三区欧美亚洲| 亚洲午夜激情网页| 国产精品毛片va一区二区三区| 亚洲最黄网站| 篠田优中文在线播放第一区| 国产精品欧美激情| 亚洲一区二区三区中文字幕| 亚洲制服av| 国产欧美大片| 久久国内精品自在自线400部| 久久综合久久久久88| 在线视频国产日韩| 欧美大片专区| 亚洲麻豆av| 午夜一区二区三区在线观看| 国产日韩欧美精品| 久久久www成人免费无遮挡大片 | 久久亚洲视频| 亚洲国产高清自拍| 欧美日韩99| 亚洲综合欧美| 欧美高清在线精品一区| 亚洲精品免费网站| 欧美日韩中文字幕| 欧美中文字幕在线观看| 免费日本视频一区| 一区二区欧美精品| 国产精品免费网站| 久久久一二三| 日韩视频一区二区三区在线播放免费观看| 中日韩视频在线观看| 国产精品亚洲视频| 久久久99爱| 一片黄亚洲嫩模| 久久久亚洲综合| 夜夜爽www精品| 国产日韩精品入口| 欧美韩日一区二区三区| 亚洲一区精品视频| 欧美国产另类| 久久国产精彩视频| 99国产精品久久久| 国产一区二区剧情av在线| 欧美激情一区二区三区| 欧美亚洲视频一区二区| 亚洲人成绝费网站色www| 欧美在线一二三| 亚洲免费福利视频| 国产一区二区中文| 欧美视频专区一二在线观看| 久久字幕精品一区| 亚洲免费在线精品一区| 亚洲国产美国国产综合一区二区| 久久精品国产精品 | 一区二区欧美激情| 在线免费观看日本一区| 国产精品尤物福利片在线观看| 毛片av中文字幕一区二区| 亚洲免费婷婷| av成人毛片| 亚洲精品自在久久| 欧美激情一区二区三区在线| 久久伊人精品天天| 欧美在线首页| 欧美一区二区三区久久精品| 99在线精品视频在线观看| 亚洲精品1区| 在线看欧美日韩| 好看的日韩av电影| 国产综合av| 国产视频久久| 国产日韩欧美一区二区三区在线观看| 欧美日韩不卡视频| 欧美精品综合| 欧美日本中文字幕| 欧美精品导航| 欧美日韩综合视频| 国产精品高潮呻吟| 国产精品theporn| 欧美性猛交xxxx免费看久久久 | 国产精品久久久久久久一区探花| 欧美日本精品一区二区三区| 欧美高清在线一区| 欧美精品xxxxbbbb| 欧美日韩亚洲系列| 欧美天堂亚洲电影院在线观看| 欧美日韩国产综合视频在线| 欧美日韩精品久久久| 欧美视频久久| 国产精自产拍久久久久久蜜| 国产伦精品一区二区三区在线观看 | 国产精品久久久久天堂| 国产精品毛片一区二区三区| 国产精品亚洲综合色区韩国| 国产欧美一区二区三区在线看蜜臀| 国产日韩欧美高清| 激情五月婷婷综合| 亚洲黄色一区二区三区| 夜色激情一区二区| 午夜精品一区二区三区四区 | 欧美在线视频一区二区| 久久这里只有| 亚洲欧洲日产国产综合网| 99国产精品99久久久久久| 亚洲综合色噜噜狠狠| 久久久久久久久蜜桃| 欧美乱妇高清无乱码| 国产精品久久久久久超碰| 国产主播精品| 日韩五码在线| 久久精品30| 亚洲国产精品久久久久秋霞不卡 | 欧美成年人网站| 国产精品99免视看9| 韩日欧美一区二区三区| 日韩一级黄色av| 久久国产精品久久精品国产 | 麻豆精品在线观看| 日韩视频中午一区| 欧美在线黄色| 欧美日韩国产限制| 伊人成人在线视频| 亚洲欧美www| 欧美成人资源| 午夜久久福利| 欧美性大战久久久久久久| 激情综合网址| 午夜亚洲精品| 亚洲日本在线视频观看| 久久av一区二区三区漫画| 欧美日韩亚洲系列| 亚洲日产国产精品| 久久午夜影视| 亚洲欧美中文另类| 欧美日韩国产色视频| 在线看片一区| 久久久久久一区二区三区| av成人手机在线| 欧美精品入口| 亚洲精品乱码久久久久| 欧美aⅴ99久久黑人专区|