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

無我

讓內(nèi)心永遠(yuǎn)燃燒著偉大的光明的精神之火!
靈活的思考,嚴(yán)謹(jǐn)?shù)膶崿F(xiàn)
豪邁的氣魄、頑強的意志和周全的思考

hash函數(shù)——djb2、sdbm、lose lose

本文內(nèi)容轉(zhuǎn)自于http://www.cse.yorku.ca/~oz/hash.html。因為他對給出了幾個非常好的hash函數(shù),而其中的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函數(shù)——djb2、sdbm、lose lose[未登錄] 2012-04-27 09:35 Tina

頂!  回復(fù)  更多評論   

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

導(dǎo)航

統(tǒng)計

公告

本博客原創(chuàng)文章,歡迎轉(zhuǎn)載和交流。不過請注明以下信息:
作者:TimWu
郵箱:timfly@yeah.net
來源:m.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>
            午夜免费电影一区在线观看| 香蕉免费一区二区三区在线观看| 欧美激情第10页| 欧美一区二区三区免费观看| 亚洲欧美日韩精品久久亚洲区| 中文精品在线| 亚洲欧美不卡| 老鸭窝91久久精品色噜噜导演| 另类尿喷潮videofree| 欧美激情一区二区三区在线| 欧美日韩精品系列| 国产精品久久久久毛片大屁完整版 | 免费在线亚洲欧美| 久久在线免费| 亚洲欧洲视频在线| 日韩亚洲国产精品| 亚洲一区在线播放| 久久精品夜色噜噜亚洲a∨| 欧美承认网站| 国产日韩在线一区| 亚洲日本中文| 欧美一区二区三区播放老司机| 亚洲伊人久久综合| 久久精品72免费观看| 欧美成人黄色小视频| 99成人在线| 久久激情中文| 国产精品爱啪在线线免费观看| 黄色成人在线观看| 一区二区av在线| 免费一区视频| 亚洲大胆av| 久久人人超碰| 米奇777在线欧美播放| 久久精品在线观看| 久久成人一区二区| 久久久久久久网站| 欧美好骚综合网| 国产免费观看久久| 久久精品二区亚洲w码| 国产农村妇女毛片精品久久麻豆 | 亚洲免费网址| 欧美成人综合网站| 久久国产精品久久w女人spa| 91久久久久久久久久久久久| 久久精品国产精品亚洲| 国产精品日韩在线观看| 一本色道久久综合亚洲精品按摩 | 欧美中文字幕在线观看| 亚洲精品视频在线| 欧美成人网在线| 在线观看的日韩av| 久久全国免费视频| 亚洲一区二区影院| 欧美视频免费在线观看| 亚洲激情婷婷| 欧美激情第一页xxx| 久久爱另类一区二区小说| 国产精品一区二区视频| 亚洲在线一区| 亚洲一区二三| 国产欧美日韩精品专区| 午夜精彩国产免费不卡不顿大片| 亚洲美女电影在线| 国产精品扒开腿做爽爽爽软件| 亚洲天堂av图片| 亚洲国产欧美一区二区三区丁香婷| 国产综合欧美| 久久久亚洲一区| 久久久999成人| 欧美激情精品久久久六区热门 | 亚洲在线免费观看| 欧美专区在线播放| 日韩视频免费观看高清完整版| 欧美激情第六页| 欧美精品videossex性护士| 99re热这里只有精品免费视频| 免费亚洲网站| 亚洲精品国产欧美| 亚洲精品一区二区在线观看| 欧美色道久久88综合亚洲精品| 亚洲一卡二卡三卡四卡五卡| 亚洲欧美日韩在线一区| 韩国一区二区三区在线观看| 欧美va天堂| 欧美日韩在线播放一区二区| 欧美一区二区久久久| 久久精品伊人| 亚洲一区欧美一区| 欧美一级久久久| 亚洲精品国产精品久久清纯直播 | 亚洲第一黄色网| 欧美深夜福利| 老司机午夜精品视频在线观看| 欧美搞黄网站| 欧美在线一级视频| 欧美凹凸一区二区三区视频| 亚洲男人的天堂在线aⅴ视频| 久久九九电影| 亚洲无限av看| 久久午夜精品一区二区| 亚洲一区黄色| 麻豆av福利av久久av| 午夜久久久久久久久久一区二区| 久久久美女艺术照精彩视频福利播放 | 亚洲欧美视频一区二区三区| 久久久久国产免费免费| 亚洲一区二区欧美| 老色批av在线精品| 亚洲影院在线| 欧美激情在线有限公司| 亚洲人成网站色ww在线| 黑人一区二区| 久久久精品2019中文字幕神马| 一本久道久久综合狠狠爱| 美女91精品| 亚洲精品一区二区网址| 亚洲一区二区精品视频| 激情视频一区| 欧美日韩1区| 欧美在线观看www| 先锋资源久久| 在线亚洲自拍| 欧美二区在线观看| 久久中文在线| 国产目拍亚洲精品99久久精品 | 欧美国产一区二区在线观看| 国产亚洲欧美色| 亚洲永久免费精品| 亚洲视频精品在线| 欧美精品手机在线| 亚洲国产成人久久| 亚洲人成人一区二区在线观看| 老司机免费视频久久| 蜜桃久久精品乱码一区二区| 国产在线精品二区| 午夜亚洲福利| 久久久久免费| 在线观看国产一区二区| 久久国产精品久久久| 久久久精品国产免费观看同学| 国产欧美精品一区| 校园春色国产精品| 久久久水蜜桃av免费网站| 韩国精品一区二区三区| 久久激情网站| 欧美大片在线看| 99国产精品久久久久久久久久| 欧美日韩国产成人在线免费| 99re6热只有精品免费观看| 亚洲一区二区精品| 国产精品天美传媒入口| 午夜在线一区二区| 欧美成人精品h版在线观看| 在线 亚洲欧美在线综合一区| 麻豆精品传媒视频| 亚洲精品国产欧美| 亚洲综合色婷婷| 国产日韩欧美综合| 久久夜色精品| 99精品视频免费观看视频| 亚洲欧美日韩综合aⅴ视频| 国产在线视频欧美| 亚洲第一色在线| 免费视频久久| 国产精品一区二区在线观看网站 | 一区二区三区精密机械公司| 欧美不卡视频一区发布| 在线一区二区三区做爰视频网站 | 最新中文字幕亚洲| 亚洲一区二区黄| 国产婷婷一区二区| 米奇777在线欧美播放| 中文一区二区在线观看| 久久天天综合| 亚洲婷婷国产精品电影人久久| 国产欧美午夜| 欧美精品国产一区| 欧美一区二区三区免费大片| 亚洲激情小视频| 性色一区二区三区| 亚洲国产高清一区| 国产日韩欧美一区| 欧美精品一区二区三区视频| 欧美一区二区三区另类| 日韩视频精品在线观看| 久久精品国产精品亚洲综合| 99国产精品久久久久久久久久 | 欧美一区二区高清在线观看| 亚洲人成高清| 国内精品久久久久伊人av| 欧美日韩亚洲系列| 美女视频一区免费观看| 欧美一级视频一区二区| 日韩视频一区二区在线观看 | 欧美r片在线| 久久精品国产99精品国产亚洲性色| 9色精品在线| 亚洲国产日韩在线| 依依成人综合视频|