布隆过滤器

✍ dations ◷ 2025-09-16 09:54:02 #函数,散列

布隆过滤器(英语:Bloom Filter)是1970年由布隆提出的。它实际上是一个很长的二进制向量和一系列随机映射函数。布隆过滤器可以用于检索一个元素是否在一个集合中。它的优点是空间效率和查询时间都远远超过一般的算法,缺点是有一定的误识别率和删除困难。

如果想判断一个元素是不是在一个集合里,一般想到的是将集合中所有元素保存起来,然后通过比较确定。链表、树、散列表(又叫哈希表,Hash table)等等数据结构都是这种思路。但是随着集合中元素的增加,我们需要的存储空间越来越大。同时检索速度也越来越慢,上述三种结构的检索时间复杂度分别为 O ( n ) , O ( log n ) , O ( 1 ) {\displaystyle O(n),O(\log n),O(1)}

布隆过滤器的原理是,当一个元素被加入集合时,通过K个散列函数将这个元素映射成一个位数组中的K个点,把它们置为1。检索时,我们只要看看这些点是不是都是1就(大约)知道集合中有没有它了:如果这些点有任何一个0,则被检元素一定不在;如果都是1,则被检元素很可能在。这就是布隆过滤器的基本思想。

相比于其它的数据结构,布隆过滤器在空间和时间方面都有巨大的优势。布隆过滤器存储空间和插入/查询时间都是常数( O ( k ) {\displaystyle O(k)} )。另外,散列函数相互之间没有关系,方便由硬件并行实现。布隆过滤器不需要存储元素本身,在某些对保密要求非常严格的场合有优势。

布隆过滤器可以表示全集,其它任何数据结构都不能;

k {\displaystyle k} m {\displaystyle m} 相同,使用同一组散列函数的两个布隆过滤器的交并运算可以使用位操作进行。

但是布隆过滤器的缺点和优点一样明显。误算率是其中之一。随着存入的元素数量增加,误算率随之增加。但是如果元素数量太少,则使用散列表足矣。

另外,一般情况下不能从布隆过滤器中删除元素。我们很容易想到把位数组变成整数数组,每插入一个元素相应的计数器加1, 这样删除元素时将计数器减掉就可以了。然而要保证安全地删除元素并非如此简单。首先我们必须保证删除的元素的确在布隆过滤器里面。这一点单凭这个过滤器是无法保证的。另外计数器回绕也会造成问题。

在降低误算率方面,有不少工作,使得出现了很多布隆过滤器的变种。

相关

  • 阿拉伯联合酋长国阿拉伯半岛(白色)阿拉伯联合酋长国(阿拉伯语:دولة الإمارات العربية المتحدة‎),通称阿联酋,是由阿布扎比、沙迦、迪拜、阿治曼、富查伊拉、乌姆盖万、
  • 爱尔兰皇家外科医学院爱尔兰皇家外科医学院,英文名Royal College of Surgeons in Ireland,简称RCSI。成立于1784年,是所私立医学院。爱尔兰皇家外科医学院位于爱尔兰的都柏林市。由于爱尔兰共和国曾
  • 美国农业部美国农业部(英语:United States Department of Agriculture,缩写:USDA),是美国联邦政府的一个行政部门,该部通过对农业生产的支持,提高美国人民的生活质量。农业部前身是1862年5月15
  • 封建制度 (中国)封建制度是一种政治制度。由共主或中央王朝给宗室成员、王族和功臣分封领地。“封建”即“封土建国(封邦建国)”,即天子把自己直接管辖的王畿以外的土地,分封给诸侯,并授予他们爵
  • 台湾之光台湾之光是一个台湾新闻媒体常用的词汇,用来指称在国际上有名气的台湾人、台湾裔人士或台湾产品,同时也是一个文化现象。台湾之光这个词汇早在2001年便开始出现在中央社和联合
  • 磁振子磁振子是晶格中电子自旋结构集体激发的准粒子。在量子力学的等效波图中,磁振子可以被看作是量化的自旋波(英语:spin wave),也就是磁性有序体的动态本征激发。磁振子携带着固定量
  • 安格斯安格斯(英语:Angus),是英国苏格兰32个一级行政区之一。面积2,182km²,人口116,240(2013年)。地处苏格兰东海岸,毗邻邓迪市,行政中心在弗福尔(Forfar)。地区内农业比较发达,名产是马铃薯
  • 买方垄断买方垄断(英语:Monopsony),也称独买、买方独占,经济学术语,指在一个市场上只存在一个买者而有许多卖者的情况。由此形成的市场称为买方垄断市场,该市场上的购买量由买方的边际价值
  • 重氮偶联反应重氮偶联反应是芳香重氮盐类和电荷密度高的芳香族化合物发生偶联反应生成偶氮化合物的反应。因为芳香重氮盐类上带正电的重氮基在芳香族化合物电荷密度够大时可以被苯环上的
  • 木村朗木村朗(1954年8月23日-) 是一名政治学家、鹿儿岛大学教授,专门是和平学。出生于北九州市小仓,北九州工业高等专门学校中途退学、入读福冈县立小仓高等学校以后升读九州大学法学部