当前位置:首页 » 编程博文
开发技术指南» 文章正文
    引言: 因为有项目需要,要做一个类似ispell的软件,其中会产生大量的对单词的查找操作,于是经过一翻研究,得出以下HASH算法,经过验证比一般的查表的FNV HASH算法产生的分布曲线基本没什么两样,并且在大部分的不同字典下,本算法要比查表的FNV HASH算法表现出速度更快,分布更均匀。
 

 

    摘要:workflow solution framework概述 microsoft workflow solution framework是一个基于biztalk server 2004工作流服务的对象框架模型,它在biztalk server 2004工作流服务所提供的api基础上进行封装,从而为上层的应用开发提供了一个的面向对象编程模型。 在使用workflow solution framew......
 ·win2000/xp下globus安装步骤    »显示摘要«
    摘要: win2000/xp下globus安装步骤 //---------------------------------------------- //ver 1.0 //by salmon //2004-10-29 9:08 //根均http://www.bigdogsoftware.org/修改、简化 //----------------------------------......


基于英文单词的快速HASH索引算法。

因为有项目需要,要做一个类似ispell的软件,其中会产生大量的对单词的查找操作,于是经过一翻研究,得出以下hash算法,经过验证比一般的查表的fnv hash算法产生的分布曲线基本没什么两样,并且在大部分的不同字典下,本算法要比查表的fnv hash算法表现出速度更快,分布更均匀.但是因为是实验结果,所以暂时还没得出有效的数学推论,但是从大量的不同的字典测试数据来看,此算法确实效率不错.

【程序编程相关:多层数据库开发十一:TClientDat

【推荐阅读:ie功能汇总(javascript)

由于以前没有涉及过相关的纯算法的设计,所以刚刚开始的时候,打算随便选用一种hash,比如说用%除大质数,然后借此搭建一个比较强壮的测试环境,然后打算根据测试结果来改进hash算法的模型. 【扩展信息:Jakarta Tomcat配置的十大技

最开始,我的hash函数是这样的:

unsigned int hash_func(char *str, int len)

{

     register unsigned int sum = 0;

     register char *p = str;

     while(p - str < len)

          sum += *(p++);

     return sum % max_prime_less_than_hash_len;

}

非常简单,但是这是绝对不可取的,通过这个函数,我选取了一个23w词的字典做为测试,当hash size=1024的时候,得到了以下的图象:

看得出震荡幅度相当大,那么如何来改进呢?首先想到可能产生的冲突的是这种情况:abcd与acbd,对于这两种单词来说,如果用上面的hash函数,就一定会发生碰撞,为什么呢?因为每个字符少了关于它自己的位置信息,于是第一次改进版本的hash函数就给每个字符加上了它的位置信息,将上面所描述的函数改进为:

unsigned int hash_func(char *str, int len)

{


...   下一页
 ·开源eai产品-retic server    »显示摘要«
    摘要:retic serverhttp://retic.sourceforge.net/xmlrpc_server.htmjpython编写,开源项目 it is a process that provides xmlrpc services to launch adaptors.it can be fully controlled remotely by retic administrator (e......
» 本期热门文章:

©2000-2007 All Rights Reserved. 最佳浏览:1024X768 MSIE