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

無我

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

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

本文內(nèi)容轉(zhuǎn)自于http://www.cse.yorku.ca/~oz/hash.html。因?yàn)樗麑o出了幾個非常好的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 閱讀(2693) 評論(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
來源: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>
            亚洲午夜免费福利视频| 午夜视频在线观看一区二区三区 | 国产一区二区在线观看免费播放| 亚洲少妇中出一区| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 欧美jizz19性欧美| 最新高清无码专区| 亚洲国产网站| 欧美日本韩国一区二区三区| 日韩一二三在线视频播| 99亚洲精品| 国产精自产拍久久久久久| 欧美亚洲免费| 久久av最新网址| 欧美一级视频免费在线观看| 国产亚洲欧美一区二区三区| 久热爱精品视频线路一| 欧美成人a∨高清免费观看| 亚洲精品资源美女情侣酒店| 这里只有精品视频| 国产一区二区精品丝袜| 欧美国产成人在线| 欧美日韩在线视频一区二区| 欧美主播一区二区三区| 麻豆av福利av久久av| 99精品视频免费全部在线| 亚洲午夜影视影院在线观看| 激情五月婷婷综合| 亚洲人人精品| 国产日韩欧美a| 亚洲日本一区二区三区| 国产一区二区三区无遮挡| 欧美高清视频| 欧美视频精品在线| 玖玖国产精品视频| 欧美日韩不卡合集视频| 久久三级福利| 欧美午夜一区| 欧美成人情趣视频| 国产欧美精品日韩| 亚洲精品一区中文| 精品91视频| 亚洲砖区区免费| 国产精品久久网| 女人色偷偷aa久久天堂| 国产精品国色综合久久| 亚洲国产日韩一区| 国内精品一区二区三区| 夜夜嗨av一区二区三区网页| 一区二区亚洲| 亚洲欧美日韩国产成人| 国产夜色精品一区二区av| 亚洲另类春色国产| 91久久国产综合久久| 欧美一区二区三区喷汁尤物| 亚洲午夜精品一区二区三区他趣| 另类综合日韩欧美亚洲| 久久久久久久久蜜桃| 国产精品一二三| 一本久久精品一区二区| 亚洲巨乳在线| 男人天堂欧美日韩| 美女视频黄免费的久久| 好看的亚洲午夜视频在线| 亚洲欧美日韩在线一区| 欧美在线91| 国产精自产拍久久久久久| 亚洲无亚洲人成网站77777| 一区二区三区精品久久久| 欧美国产日韩亚洲一区| 欧美国产精品人人做人人爱| 在线播放日韩专区| 久久久999国产| 久久字幕精品一区| 影音先锋久久精品| 久久婷婷成人综合色| 免费成人网www| 亚洲国产激情| 欧美国产日韩亚洲一区| 亚洲精品一二| 亚洲欧美日韩国产另类专区| 国产精品视区| 欧美怡红院视频| 久久综合一区| 亚洲狠狠丁香婷婷综合久久久| 老巨人导航500精品| 亚洲国产精品美女| 亚洲视频在线观看一区| 国产精品丝袜白浆摸在线| 性色av一区二区怡红| 久久综合国产精品| 亚洲每日更新| 国产精品日韩二区| 久久爱www.| 亚洲国产成人精品久久| 亚洲无吗在线| 国产午夜久久久久| 老鸭窝亚洲一区二区三区| 亚洲人人精品| 亚洲欧美国产高清| 国内精品久久久久影院薰衣草| 欧美va亚洲va日韩∨a综合色| 亚洲精选一区二区| 久久高清一区| 一本久道久久久| 欧美ed2k| 亚洲影音先锋| 亚洲电影欧美电影有声小说| 亚洲欧美卡通另类91av| 亚洲第一中文字幕| 国产精品福利久久久| 久久久久国产一区二区| 日韩亚洲欧美成人一区| 久久综合图片| 亚洲一区三区电影在线观看| 亚洲第一色中文字幕| 国产精品国产精品| 免费观看亚洲视频大全| 亚洲欧美国产77777| 欧美激情一区二区三区成人| 欧美专区福利在线| 一本色道久久综合亚洲精品小说 | 欧美精品入口| 久久精品国产成人| 一本一本a久久| 亚洲第一精品福利| 久久久久久亚洲精品杨幂换脸| 亚洲午夜性刺激影院| 亚洲福利专区| 国产亚洲成精品久久| 欧美视频一二三区| 欧美黑人多人双交| 久久偷窥视频| 欧美在线网址| 午夜精品一区二区在线观看| 一级成人国产| 亚洲精选一区二区| 亚洲精品免费观看| 欧美不卡高清| 麻豆久久精品| 麻豆精品在线播放| 久热精品视频在线观看| 久久久夜夜夜| 久久精品99无色码中文字幕| 欧美一区二区三区在| 亚洲欧美成人精品| 亚洲欧美中文字幕| 亚洲欧美日韩另类| 午夜精品一区二区三区四区| 亚洲一区二区三区乱码aⅴ蜜桃女| 一本一本久久a久久精品综合妖精| 亚洲激情女人| 99视频精品免费观看| 日韩视频免费在线| 99爱精品视频| 亚洲作爱视频| 亚洲香蕉网站| 欧美中文在线观看国产| 久久国产精彩视频| 久久一二三国产| 免费在线视频一区| 欧美激情第五页| 亚洲精品男同| 在线一区免费观看| 亚洲与欧洲av电影| 久久精品盗摄| 你懂的亚洲视频| 欧美女同视频| 国产精品私房写真福利视频| 国产一区二区三区四区hd| 在线观看一区| 日韩视频一区二区在线观看 | 亚洲欧洲视频在线| 在线午夜精品| 欧美综合二区| 欧美不卡激情三级在线观看| 亚洲国产精品悠悠久久琪琪| 一本色道久久综合狠狠躁篇怎么玩| 亚洲午夜视频在线观看| 久久精品成人| 欧美精品一区在线播放| 国产精品久久国产精品99gif | 国产精品国码视频| 国内外成人免费激情在线视频| 亚洲国产经典视频| 亚洲欧美成人在线| 欧美freesex交免费视频| 一本一本久久a久久精品综合妖精| 欧美亚洲综合在线| 欧美美女福利视频| 黄色成人av| 在线一区二区三区四区| 麻豆av福利av久久av| 一区二区三区久久| 免费欧美高清视频| 国产欧美日本| 亚洲图片在线| 欧美大片专区| 欧美亚洲视频一区二区| 欧美日韩午夜激情|