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

無我

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

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>
            另类图片国产| 欧美韩日一区二区三区| 亚洲视频一区在线观看| 欧美色图首页| 欧美一进一出视频| 久久久久国内| 亚洲精品永久免费精品| 亚洲人午夜精品| 欧美体内she精视频| 亚洲欧美激情在线视频| 欧美一区在线看| 亚洲人成毛片在线播放| 亚洲精品乱码久久久久久日本蜜臀| 欧美国产在线电影| 亚洲综合电影| 久久综合给合| 一本综合久久| 欧美一区午夜精品| 亚洲乱码国产乱码精品精天堂 | 亚洲视频一区在线| 亚洲图片在线| 亚洲大片精品永久免费| 亚洲精品美女久久久久| 国产精品综合网站| 欧美激情一区二区三区四区| 欧美色网在线| 欧美黄色片免费观看| 欧美日韩在线视频一区二区| 久久久久久黄| 欧美视频亚洲视频| 美女网站在线免费欧美精品| 欧美性猛交一区二区三区精品| 久久国产精品网站| 欧美国产三区| 久久青草久久| 国产精品私拍pans大尺度在线| 男女激情久久| 国产一区亚洲| 在线视频精品一| 亚洲精选91| 久久综合狠狠| 久久亚洲综合色| 国产精品久久久久久影视| 亚洲黄色影片| 亚洲高清一区二| 久久国产88| 欧美在线影院在线视频| 欧美日韩伊人| 亚洲欧洲一区二区三区久久| 在线观看一区视频| 亚洲欧美日韩精品久久亚洲区 | 免费不卡在线视频| 亚洲欧美日韩爽爽影院| 欧美大胆成人| 欧美成人国产一区二区| 韩国av一区二区三区在线观看| 99精品久久| 在线午夜精品| 欧美巨乳在线观看| 最新日韩在线| 亚洲精品美女91| 另类激情亚洲| 欧美大片在线看| 亚洲国产精品久久久久| 久久亚洲精选| 欧美激情2020午夜免费观看| 亚洲电影免费| 麻豆九一精品爱看视频在线观看免费 | 免费欧美在线视频| 欧美成人伊人久久综合网| 伊人夜夜躁av伊人久久| 久久久久高清| 欧美大学生性色视频| 亚洲破处大片| 欧美色综合网| 亚洲欧美日韩国产中文在线| 午夜影院日韩| 国内精品美女在线观看| 久久精品一区二区三区四区| 狼狼综合久久久久综合网 | 国产欧美日韩视频在线观看 | 欧美a级片一区| 亚洲人被黑人高潮完整版| 免费一级欧美片在线观看| 亚洲黄色免费电影| 亚洲欧美另类在线观看| 国产有码一区二区| 女人色偷偷aa久久天堂| 日韩性生活视频| 久久国产精品亚洲va麻豆| 国内精品久久久久久影视8 | 亚洲欧美日韩电影| 久久婷婷综合激情| 亚洲乱码日产精品bd| 国产精品国产三级国产专播精品人 | 亚洲天堂免费观看| 国产一区二区三区的电影| 久久人人爽国产| 一本色道久久综合狠狠躁篇的优点 | 亚洲国产精品一区制服丝袜 | 国产目拍亚洲精品99久久精品| 久久aⅴ国产欧美74aaa| 亚洲激情六月丁香| 欧美在线观看www| 在线日韩中文字幕| 国产精品久久久久久久久久久久久| 欧美专区在线播放| 亚洲最新视频在线| 欧美1级日本1级| 亚洲欧美日韩中文播放| 亚洲国产日韩欧美一区二区三区| 国产精品久久久99| 米奇777在线欧美播放| 亚洲综合色视频| 亚洲精品视频免费| 蜜臀av国产精品久久久久| 亚洲欧美日韩精品一区二区| 亚洲大片一区二区三区| 国产区日韩欧美| 欧美日韩免费观看一区三区| 久久噜噜噜精品国产亚洲综合| 一区二区三区日韩在线观看| 欧美二区在线看| 久久久国产91| 欧美在线播放视频| 午夜精品999| 亚洲摸下面视频| 亚洲视频一区| 99精品国产在热久久婷婷| 亚洲国产精品一区二区第一页| 国产主播在线一区| 国产日韩综合| 国产视频在线观看一区| 国产精品免费看片| 国产精品久久久久久久第一福利| 欧美激情成人在线| 欧美国产日韩一区二区三区| 久久久91精品| 久久精品中文| 久久久久久综合| 久久精品人人爽| 久久久久88色偷偷免费| 久久av资源网站| 久久久久久久精| 久久在线视频在线| 久热精品视频在线观看一区| 久久精品91| 老司机一区二区三区| 久久综合色天天久久综合图片| 久久欧美中文字幕| 欧美顶级艳妇交换群宴| 欧美激情免费观看| 欧美日韩中文字幕在线视频| 欧美视频你懂的| 国产精品免费一区豆花| 国产日韩在线一区| 亚洲成色www8888| 亚洲免费不卡| 性欧美超级视频| 蜜桃av久久久亚洲精品| 亚洲福利视频免费观看| 99热精品在线| 亚洲欧美综合另类中字| 久久视频一区| 欧美日韩成人激情| 国产精品亚洲综合一区在线观看| 国产日韩欧美综合在线| 亚洲电影在线播放| 一本色道久久综合狠狠躁篇怎么玩| 一区二区三区欧美日韩| 欧美一区二区三区电影在线观看| 久久人人97超碰精品888| 免费久久久一本精品久久区| 亚洲精品欧美激情| 欧美一级淫片aaaaaaa视频| 老**午夜毛片一区二区三区| 欧美日韩午夜精品| 国产在线不卡视频| 99在线热播精品免费99热| 欧美影院视频| 最新亚洲一区| 午夜精品一区二区三区在线播放| 老妇喷水一区二区三区| 国产精品v欧美精品∨日韩| 国外成人在线视频| 一本色道久久综合亚洲精品按摩 | 久热精品视频在线观看| 亚洲精品在线一区二区| 久久国产直播| 欧美午夜视频在线| 亚洲国产精品一区二区久 | 亚洲精品视频免费观看| 欧美一区二区三区四区在线| 欧美激情视频在线播放| 性做久久久久久| 欧美视频三区在线播放| 亚洲国产一区二区三区青草影视| 欧美一区二区视频在线观看2020| 亚洲激情综合| 久久琪琪电影院|