陈皓专栏 【空谷幽兰,心如皓月】

芝兰生于深谷,不以无人而不芳;君子修道立德,不为困穷而改节。

用户操作
[即时聊天] [发私信] [加为好友]
陈皓ID:haoel
485128次访问,排名97好友51人,关注者74
芝兰生于空谷,不以无人而不芳;君子修道立德,不为困穷而改节。
haoel的文章
原创 71 篇
翻译 0 篇
转载 0 篇
评论 1052 篇
陈皓的公告
Email & MSN
haoel@hotmail.com
最近评论
liuxi:LS 两个command都是命令的意思 例如 cc -o test.o -c -g test.c这样的命令.
targets : prerequisites ; command
command
这个的意思是命令你可以选择写在先决条件(prerequisites)的后面用分号隔开;也可以另起一行用tab开始些命令。
figoshen:楼上的,楼主的程序我跑了没有问题,你说的的多加(int*)是问题我觉得加不加都一样了
silvervi:大哥,文章有错误

在VS 2005里面加了断点专门跑了一下,对照局部变量里面虚函数表的实际地址,错误跟我之前想的一样,少了一次解引用

正确的应该如下

cout << "虚函数表地址:" << (int *)*(int *)(&b) << endl;

cout &……
miansha:走过留名

谢谢LZ,学习并谨记
new_my_program:我还是个学生,但就我们学生的角度来看,像清华大学出版社你们这些人是没资格出书的。一个老师如果教育学生犯罪那就是个垃圾老师,你们出书的本来更是影响几代人,比一般的老师的影响力更大的多,你们的垃圾程度是可想而知的。以前看了《清华梦的破灭》这个文章后,我对心目中的清华园产生了严重的鄙视,现在再看了陈皓大哥的帖子,我更是鄙视你们。进清华的学生是何等的厉害,何等的意气风发。但是出清华的学生呢,好的就留……
文章分类
收藏
    相册
    我的BLOG
    耗子小筑(非技术)(RSS)
    陈皓专栏(技 术)(RSS)
    存档
    订阅我的博客
    XML聚合  FeedSky
    订阅到鲜果
    订阅到Google
    订阅到抓虾
    订阅到BlogLines
    订阅到Yahoo
    订阅到GouGou
    订阅到飞鸽
    订阅到Rojo
    订阅到newsgator
    订阅到netvibes

    原创 哈希表心得收藏

    新一篇: 用C写有面向对象特点的程序 | 旧一篇: 用C写有面向对象特点的程序

    最近我在做一个项目,其中要用到一个数据结构——Hash Table(哈希表),以前只有理论知识,现在实却发现很不简单,所以写下来和大家共分享。

    我们知道,哈希表是一个固定大小的数组,数组的每个元素是一个链表(单向或双向)的头指针。如果Key一样,则在一起,如果Key不一样,则不在一起。哈希表的查询是飞快的。因为它不需要从头搜索,它利用Key的“哈希算法”直接定位,查找非常快,各种数据库中的数据结构基本都是它。但带来的问题是,哈希表的尺寸、哈希算法。

    哈希表的数组是定长的,如果太大,则浪费,如果太小,体现不出效率。合适的数组大小是哈希表的性能的关键。哈希表的尺寸最好是一个质数,最小的质数尺寸是17。

    当然,根据不同的数据量,会有不同的哈希表的大小。对于数据量很时多时少的应用,最好的设计是使用动态可变尺寸的哈希表,那么如果你发现哈希表尺寸太小了,比如其中的元素是哈希表尺寸的2倍时,我们就需要扩大哈希表尺寸,一般是扩大一倍。下面的数库是哈希表变化尺寸时尺寸大小的一个列表。

    static int prime_array[] = {
        17,             /* 0 */
        37,             /* 1 */
        79,             /* 2 */
        163,            /* 3 */
        331,            /* 4 */
        673,            /* 5 */
        1361,           /* 6 */
        2729,           /* 7 */
        5471,           /* 8 */
        10949,          /* 9 */
        21911,          /* 10 */
        43853,          /* 11 */
        87719,          /* 12 */
        175447,         /* 13 */
        350899,         /* 14 */
        701819,         /* 15 */
        1403641,        /* 16 */
        2807303,        /* 17 */
        5614657,        /* 18 */
        11229331,       /* 19 */
        22458671,       /* 20 */
        44917381,       /* 21 */
        89834777,       /* 22 */
        179669557,      /* 23 */
        359339171,      /* 24 */
        718678369,      /* 25 */
        1437356741,     /* 26 */
        2147483647      /* 27 (largest signed int prime) */
    };               

    #define PRIME_ARRAY_SIZE  (28)
     


    要使用哈希表,就一定要用一个哈希算法,来确定KEY值,这似乎是个很难的事,下面是一个哈希算法:

    typedef struct _hTab{
        hLinks* link;    /* 一个链表 */
        int  num;     /* 成员个数 */
        int  size;    /* 表的尺寸 */
    } hTab;

    static unsigned int
    getHashIndex(hTab *tabPtr, const char *key)
    {
        unsigned int ha = 0;
      
        while (*key)
            ha = (ha * 128 + *key++) % tabPtr->size;

        return ha;

    }

    (其中key是一个字符串,hTab就是一个哈希表结构, tabPtr->size是哈希表数组的大小)

    这个算法被实施证明是比较不错的,能够达到分散数据的效果,如果你有更好的算法,欢迎和我交流。(litmouse@km169.net

    ————
    (版权所有,如需转载,请注明出处及作者)

    发表于 @ 2003年04月02日 09:02:00|评论(loading...)|编辑

    新一篇: 用C写有面向对象特点的程序 | 旧一篇: 用C写有面向对象特点的程序

    评论

    #ovo 发表于2006-09-17 21:15:00  IP: 59.44.116.*
    getHashIndex(hTab *tabPtr, const char *key)
    {
    unsigned int ha = 0;

    while (*key)
    ha = (ha * 128 + *key++) % tabPtr->size;

    return ha;

    }


    经实际测试,上面这个算法冲突很多,下面这个优于上面这一个:

    unsigned long getHashIndex( const char *key, int nTableLength )
    {
    unsigned long nHash = 0;

    while (*key)
    {
    nHash = (nHash<<5) + nHash + *key++;
    }

    return ( nHash % nTableLength );
    }

    ---------------------------
    MPQ中的Hash算法比上面的要复杂一点,更好一些


    #ovo 发表于2006-09-17 21:18:00  IP: 59.44.116.*
    测试用的数据是40万的英语单词
    #陈皓 发表于2006-09-20 18:33:00  IP: 210.82.49.*
    感谢ovo的回复。
    #lucliff 发表于2007-08-09 18:45:01  IP: 218.104.71.*
    学习了
    发表评论  


    登录
    Csdn Blog version 3.1a
    Copyright © 陈皓