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

無我

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

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 閱讀(2694) 評論(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热这里只有成人精品国产| 亚洲人成网站在线播| 午夜一级在线看亚洲| 国产亚洲观看| 久久综合给合久久狠狠色| 久久久亚洲国产美女国产盗摄| 亚洲国产精品视频| 亚洲欧洲在线一区| 国产精品久久久久久久久久久久| 性欧美xxxx视频在线观看| 久久国产精品99国产| 91久久国产综合久久| 99天天综合性| 国产视频在线观看一区二区三区| 美女国产精品| 欧美裸体一区二区三区| 校园春色综合网| 久久综合99re88久久爱| 99热这里只有成人精品国产| 亚洲欧美成人| 在线电影一区| 亚洲美女免费精品视频在线观看| 国产麻豆9l精品三级站| 欧美ab在线视频| 欧美午夜视频在线| 久久性色av| 欧美精品在线看| 久久精品99国产精品| 欧美成人国产| 欧美一区二区三区视频在线观看| 久热爱精品视频线路一| 亚洲一二三四区| 久久久久久久久伊人| 国产精品99久久久久久久久| 久久av在线看| 中文在线资源观看网站视频免费不卡| 欧美伊久线香蕉线新在线| 亚洲精品麻豆| 欧美亚洲三区| 亚洲日韩成人| 亚洲欧美制服中文字幕| 亚洲精品中文字幕女同| 欧美一区二区视频在线观看2020| 99精品国产在热久久婷婷| 午夜在线观看欧美| 亚洲青涩在线| 欧美一区二区视频在线| 一区二区三区蜜桃网| 久久久久久久999| 亚洲欧美视频一区二区三区| 久久亚洲色图| 欧美一区二区三区视频免费| 欧美片第一页| 蜜乳av另类精品一区二区| 国产精品久久久久久久浪潮网站| 欧美国产日韩在线| 国产一区二区黄色| 亚洲最新视频在线播放| 亚洲国产日韩欧美| 欧美制服丝袜| 亚洲网站在线观看| 美女精品网站| 久久欧美中文字幕| 国产精品理论片| 亚洲日本成人女熟在线观看| 精品成人免费| 香蕉久久精品日日躁夜夜躁| 亚洲午夜一二三区视频| 欧美成人一区二免费视频软件| 久久精品官网| 国产精品视频第一区| 亚洲精品在线免费| 亚洲黄色大片| 久久蜜臀精品av| 久久精品在线| 国产欧美精品日韩区二区麻豆天美| 亚洲精品欧美| 亚洲人成人99网站| 久久亚洲精品中文字幕冲田杏梨| 久久精品日韩一区二区三区| 国产精品日韩欧美一区二区三区| 亚洲裸体视频| 99成人免费视频| 免费一级欧美片在线播放| 久久伊人免费视频| 国产真实精品久久二三区| 亚洲摸下面视频| 亚洲女同同性videoxma| 欧美日韩精品久久久| 91久久精品国产91性色| 亚洲黄色在线看| 另类亚洲自拍| 老鸭窝毛片一区二区三区| 国产综合精品一区| 欧美在线一区二区| 久久久亚洲欧洲日产国码αv| 国产欧美精品国产国产专区| 亚洲欧美国产精品桃花| 亚洲欧美福利一区二区| 国产精品igao视频网网址不卡日韩 | 欧美国产日韩一区二区三区| 尤物在线精品| 久久综合婷婷| 欧美激情91| 亚洲欧洲日韩综合二区| 欧美成人性生活| 亚洲精品国产品国语在线app| 亚洲区欧美区| 欧美激情一区二区三区| 亚洲精品中文字幕在线| 一区二区三区欧美在线观看| 欧美日韩不卡视频| aa亚洲婷婷| 午夜久久久久久| 国产精品男gay被猛男狂揉视频| 一本大道久久a久久综合婷婷| 国产精品99久久久久久久久| 欧美性猛交一区二区三区精品| 亚洲图片欧洲图片av| 欧美一区二区三区日韩视频| 国内外成人在线| 久久综合色影院| 亚洲欧洲在线视频| 亚洲永久免费观看| 国产精品亚洲а∨天堂免在线| 午夜一区二区三区在线观看| 老司机aⅴ在线精品导航| 亚洲国内高清视频| 欧美日韩国产成人精品| 亚洲视频免费| 久久噜噜亚洲综合| 亚洲国产另类久久久精品极度| 欧美激情按摩在线| 一区二区日韩欧美| 久久爱www.| 亚洲高清免费视频| 欧美日本国产一区| 亚洲在线观看视频| 久久综合狠狠| 一区电影在线观看| 国产日韩成人精品| 久久综合久久久| 日韩一级欧洲| 久久国产综合精品| 亚洲成色777777女色窝| 欧美激情亚洲综合一区| 亚洲系列中文字幕| 猫咪成人在线观看| 一区二区三区免费观看| 国产一区二区三区免费观看 | 老司机一区二区| 日韩一级精品| 国产精品视频福利| 美女在线一区二区| 亚洲视频在线播放| 美女国产精品| 亚洲一区影院| 激情五月***国产精品| 欧美伦理视频网站| 久久国产精品一区二区三区四区| 亚洲国产精品一区二区www| 亚洲欧美日韩综合| 亚洲国产精品99久久久久久久久| 欧美—级高清免费播放| 欧美一级网站| 亚洲精品一区二| 久久久久久久性| 一区二区三区日韩在线观看| 国际精品欧美精品| 欧美日韩另类在线| 久久久久久久成人| 在线性视频日韩欧美| 久热re这里精品视频在线6| 宅男在线国产精品| 在线播放中文一区| 欧美性猛交99久久久久99按摩| 久久久精品日韩| 亚洲午夜一区二区| 亚洲高清在线观看| 久久er精品视频| 亚洲视频导航| 亚洲国产精品久久| 国产免费一区二区三区香蕉精| 欧美激情精品久久久| 欧美在线三区| 在线一区二区视频| 亚洲国产精品va在线看黑人| 欧美一区二区三区啪啪| 一本色道久久加勒比88综合| 伊人激情综合| 国产日韩综合一区二区性色av| 欧美日韩国产一区| 久久蜜桃av一区精品变态类天堂| 亚洲女性喷水在线观看一区| 亚洲三级色网| 欧美黄色免费| 久久久午夜精品| 性欧美暴力猛交69hd| 一区二区三区日韩欧美| 亚洲精品一区二区三区樱花|