hash之于查找

hash算法精髓在key的全集较大,而实际结果集远小于全集,hash将一个大范围的结果集缩小到一个小的结果集中,hash值相同的key值放在一个数组中去,更便于key值命中,以概率论,时间复杂度为O(1),

简单的hash算法

加法Hash就是把输入元素一个一个的加起来构成最后的结果。标准的加法Hash的构造如下:

static int additiveHash(String key, int prime)

{

int hash, i;

for (hash = key.length(), i = 0; i < key.length(); i++)

hash += key.charAt(i);

return (hash % prime);

}

这里的prime是任意的质数,看得出,结果的值域为[0,prime-1]。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第一章 Nginx简介 Nginx是什么 没有听过Nginx?那么一定听过它的“同行”Apache吧!Ngi...
    JokerW阅读 32,836评论 24 1,002
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,823评论 18 399
  • 一、基本数据类型 注释 单行注释:// 区域注释:/* */ 文档注释:/** */ 数值 对于byte类型而言...
    龙猫小爷阅读 4,297评论 0 16
  • 曼妙的午后,小憩一会儿。暖风中飘来咖啡的味道,办公桌对面的姑娘奋笔疾书,剩下的三两小伙伴们像打了鸡血一般地背诵着下...
    飞儿FLY阅读 350评论 0 0
  • 自己真的是一个很自私的人。心情不美丽又失眠的时候咋整。
    一个讨厌自己的双鱼女阅读 199评论 0 0