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

無我

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

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>
            久久综合999| 亚洲少妇自拍| 久久爱www久久做| 9l国产精品久久久久麻豆| 美女久久一区| 1024亚洲| 免费看的黄色欧美网站| 欧美亚洲免费| 欧美三级小说| 亚洲欧美电影在线观看| 亚洲免费观看高清完整版在线观看| 美女亚洲精品| 国内揄拍国内精品少妇国语| 久久国产精品一区二区三区| 午夜欧美不卡精品aaaaa| 欧美日韩高清一区| 亚洲天堂免费在线观看视频| 99国产精品99久久久久久| 欧美另类极品videosbest最新版本| 最新国产精品拍自在线播放| 亚洲黑丝一区二区| 欧美另类极品videosbest最新版本| 一本高清dvd不卡在线观看| 亚洲欧洲精品一区| 欧美香蕉大胸在线视频观看| 亚洲欧美日韩一区在线| 欧美一区=区| 91久久精品国产91久久| 日韩视频免费在线观看| 国产精品久久久久9999吃药| 久久精品官网| 久热精品视频在线| 亚洲一区二三| 久久er精品视频| 亚洲精品美女在线| 亚洲午夜高清视频| 国产精品久久亚洲7777| 久久在线播放| 欧美日本在线一区| 欧美专区在线观看| 欧美大片在线观看一区| 午夜精品视频在线观看| 久久蜜桃香蕉精品一区二区三区| 亚洲欧洲一区二区天堂久久| 在线视频日韩| 在线日韩av| 亚洲国产精品成人一区二区 | 一本大道av伊人久久综合| 99riav国产精品| 黄色在线成人| 一区二区三区四区五区在线| 黄色亚洲免费| 亚洲午夜激情免费视频| 亚洲国产精品视频一区| 亚洲视频网在线直播| 亚洲大胆视频| 亚洲欧美日韩精品一区二区| 亚洲欧洲一区二区三区在线观看| 亚洲一区在线免费观看| 亚洲人www| 牛牛国产精品| 欧美激情一区二区三区成人| 在线成人激情黄色| 久久久久一区二区三区| 久久综合九色综合久99| 国产真实乱子伦精品视频| 亚洲欧美日本伦理| 香蕉乱码成人久久天堂爱免费| 欧美性猛交一区二区三区精品| 亚洲精品偷拍| 在线亚洲国产精品网站| 欧美视频中文一区二区三区在线观看| 亚洲国产日韩在线| 99在线精品视频在线观看| 欧美激情一区二区三区不卡| 亚洲精品视频在线观看网站| 日韩一级在线观看| 欧美午夜激情小视频| 亚洲视频在线观看一区| 久久99伊人| 在线播放国产一区中文字幕剧情欧美| 久久精品国产免费观看| 欧美.日韩.国产.一区.二区| **欧美日韩vr在线| 欧美激情1区2区3区| 夜夜嗨av一区二区三区中文字幕| 亚洲欧美成人在线| 好吊色欧美一区二区三区视频| 久久婷婷国产综合国色天香| 亚洲高清二区| 亚洲欧美日韩国产成人精品影院| 国产精品香蕉在线观看| 久久精品免费观看| 亚洲理伦电影| 久久国产高清| 亚洲精品少妇网址| 国产精品久久久久9999| 久久激情久久| 日韩视频精品在线| 久久婷婷人人澡人人喊人人爽| 亚洲激情电影中文字幕| 欧美性做爰毛片| 久久久久久一区二区三区| 91久久精品网| 久久久久亚洲综合| 一本色道久久综合亚洲精品高清| 国产美女扒开尿口久久久| 老司机午夜精品视频| 亚洲图片自拍偷拍| 亚洲国产成人精品女人久久久 | 日韩亚洲欧美高清| 国产亚洲精品bt天堂精选| 欧美a级在线| 校园激情久久| 99在线|亚洲一区二区| 六月天综合网| 先锋影音一区二区三区| 日韩视频一区二区三区| 国产亚洲一区精品| 欧美色123| 欧美成人一品| 久久久久.com| 欧美一级播放| 亚洲视屏在线播放| 9i看片成人免费高清| 亚洲国产另类久久久精品极度| 久久黄色网页| 欧美一区二区三区男人的天堂 | 极品av少妇一区二区| 国产精品久久福利| 欧美区在线播放| 麻豆精品传媒视频| 久久久久国内| 欧美在线视频一区二区三区| 亚洲一区二区黄| 在线一区二区视频| 日韩亚洲欧美成人| 亚洲久久视频| 亚洲精品日韩在线观看| 亚洲激情欧美| 最新中文字幕亚洲| 亚洲国产一区二区视频| 免费亚洲电影在线| 久久综合影视| 免费中文字幕日韩欧美| 乱中年女人伦av一区二区| 久久久国产一区二区三区| 久久精品成人| 久久婷婷成人综合色| 久久久精品999| 久久免费国产精品1| 美女精品在线| 欧美电影在线播放| 亚洲国产精品视频一区| 最近中文字幕日韩精品 | 亚洲一级片在线观看| 一区二区高清视频| 亚洲主播在线播放| 久久国内精品视频| 美女脱光内衣内裤视频久久网站| 老色鬼精品视频在线观看播放| 六十路精品视频| 欧美区在线观看| 国产精品久久久一区二区| 国产人久久人人人人爽| 一区二区在线免费观看| 亚洲欧洲另类国产综合| 中文精品视频一区二区在线观看| 亚洲一区二区三区免费视频 | 亚洲另类春色国产| 亚洲午夜免费福利视频| 久久成人精品一区二区三区| 另类尿喷潮videofree| 亚洲国产天堂久久国产91| 中文精品视频| 久久夜色精品国产欧美乱| 欧美日韩小视频| 国产色产综合产在线视频| 亚洲激情网站| 香蕉成人伊视频在线观看 | 久久婷婷影院| 亚洲人成在线播放| 午夜在线成人av| 欧美精品福利| 国产一区欧美| 亚洲视频在线观看| 免费久久99精品国产自| 99re热精品| 麻豆av一区二区三区| 欧美性片在线观看| 亚洲国产精品一区二区www在线| 亚洲综合色婷婷| 亚洲第一毛片| 久久国产一二区| 国产精品免费一区豆花| 日韩视频―中文字幕| 久久综合中文字幕| 亚洲欧美中文日韩v在线观看| 欧美黄色一区二区| 韩日欧美一区二区三区|