我需要在C#中存储4000字符串的固定大小(8字符),但是我不知道
关于添加和检索项目的空间和时间最好使用什么:布隆过滤器,哈希表或词典?请任何人可以帮助我

解决方法

在这个问题中,你真的只有C#中的两个数据结构,因为C#中的字典是使用哈希表来实现的.所以我们将引用Dictionary和HashTable作为哈希表.如果你使用其中的一个,那么你可能希望Dictionary由于类型的安全性和性能如下所示: Why is Dictionary preferred over hashtable?但是作为一个字典是使用哈希表实现的,两者之间并不是很大的区别.

但真正的问题是哈希表(Dictionary)与Bloom过滤器.有人曾经问过相关的问题,What is the advantage to using bloom filters?他们还链接到Bloom过滤器的维基百科页面,这是非常翔实的:https://en.wikipedia.org/wiki/Bloom_filter答案的简短版本是Bloom过滤器越来越小.然而,他们确实有与此相关的成本:它们不完全准确.在哈希表中,始终存储原始字符串以进行精确比较.首先,您将哈希的值,并告诉你在表中的哪一个看.查看表格后,您可以根据您要搜索的值检查位于该值的值.在Bloom过滤器中,您可以使用多个哈希值来计算一组位置.如果所有这些位置都有1,那么你会考虑找到这个字符串.这意味着有时字符串将被“发现”,最初没有被插入.如果表格太小,实际上可以达到一个饱和点,在这个点上,您尝试的任何字符串都将出现在Bloom过滤器中.因为你知道要插入多少个字符串,所以你可以适当地调整表的大小来避免这种情况.

我们来看看所涉及的大小.为了使数字清晰地出来,我要假装你有4096个字符串.要具有相对较低的碰撞哈希表,您希望您的表至少与字符串数量一样大.所以,实际上(假设32位(4字节)指针),在这种情况下,你会看到表的4096 * 4字节= 16K的大小,加上4096 *(4 4 8)= 64K的列表节点(下一个指针字符串指针)和字符串.所以,总共可能是大约80K,这在大多数情况下可能不是很多内存,你将使用C#.

对于Bloom过滤器,我们必须在我们的尺寸计算中确定我们想要的错误率.当我们讨论1%的错误率时,这意味着在每100个未插入布隆过滤器的字符串中,1将被错误地表示为存在.插入的字符串将始终被正确地表示为插入.使用方程m = -n * ln(p)/(ln(2)^ 2),我们可以计算最小尺寸给我们一定的错误率.在该等式中,m是表中的时隙数,p是错误率,n是要插入的字符串数.所以,如果我们将p设置为0.01(1%误差),那么我们得到大约9.6 * 4096位= 9.6 * 512字节= 4.8K,这显然是相当小的.但是,真正的1%是错误率的高.所以更实际的是,我们应该去更像0.0001%的东西,它出现在28.8 * 4096b位= 28.8 * 512字节= 14.4K.显然,其中任何一个都比我们为散列表计算的80K小得多.然而,散列表的错误率为0,明显小于1%或0.0001%.

那么真的,由你自己决定,在你的情况下,如何获得一定的准确性,一点点的速度和一点时间就是值得的.实际上,对于绝大多数现实世界的情况,任何一种选择都可能足够小,足够快.

c# – 哪个最好的时间和空间:布鲁姆过滤器,哈希表或字典?的更多相关文章

  1. iOS上的C#库

    我已经完成了droid开发,答案就是创建一些使用我的C#库的Web服务,然后让droid使用这些服务.我假设同样的方法适用于iOS(正确的???

  2. 《Swift NSDictionary 的详细使用和部分方法介绍 和 哈希表散列)的阐述和解释 》

    /*《SwiftNSDictionary的详细使用和部分方法介绍和哈希表(散列)的阐述和解释》*//*第一步:我们首先,必须了解一个概念性的东西那就是:哈希哈希的主要解释是:哈希算法将任意长度的二进制值映射为较短的固定长度的二进制值,这个小的二进制值称为哈希值。2》哈希列表是跟进式变化的。作为线性数据结构与表格和队列等相比,哈希表无疑是查找速度比较快的一种。在哈希方法中使用的转换函数hash被称作哈希函数。按照此中算法构造出来的表叫做哈希表。

  3. Swift 中“等同性”、“比较”、“哈希” 概念理解

    甚至某些场景下还需要将其作为键值对中的Key,这就涉及到哈希函数以及哈希值的碰撞问题了。不过仔细查看代码,我们会发现上诉冲突的原因之一就是name、capital属性采用了同样的哈希函数。并修改Country中的哈希实现:改进后上诉冲突得以解决:总结本文简单的介绍了Swift中“等同性”、“比较”、“哈希”的概念,并对一些常见哈希冲突进行了分析。

  4. Swift 2.0协议扩展和Java / C#抽象类之间有区别吗?

    通过在Swift2.0中添加协议扩展,似乎协议基本上成为Java/C#抽象类.我唯一可以看到的不同之处在于抽象类限制为单一继承,而Swift类型可以符合任何数量的协议.这是对Swift2.0中的协议的正确理解,还是有其他差异?有几个重要的区别…

  5. Swift有一个隐式的Object Initializer,就像在C#中一样吗?

    在C#中,我们有对象初始化器,像这样:Swift有这个吗?例如,我有这个代码:但是想做以下一些事情:谢谢!

  6. Dictionary如何在Swift中使用Equatable协议?

    focusedCommentId=19980&page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel#comment-19980What’sactuallyhappening:Wehashavalueonlyonceoninsertion.Wedon’tusehashesforcomparisonofelements,only==.Usinghashesforcomparisonisonlyreasonableifyous

  7. Android的C#版本的Console.WriteLine?

    在Android中,写入控制台的最佳方式是什么.在C#中,我使用Log4Net或只使用Console.Write解决方法查看Android.Util.Log的帮助页面.您可以使用:

  8. Android上的C#:Xamarin或Unity?

    还是有其他解决方案?

  9. Java超详细分析讲解哈希表

    哈希表是一种根据关键码去寻找值的数据映射结构,该结构通过把关键码映射的位置去寻找存放值的地方,说起来可能感觉有点复杂,我想我举个例子你就会明白了,最典型的的例子就是字典

  10. jQuery+C#实现参数RSA加密传输功能【附jsencrypt.js下载】

    这篇文章主要介绍了jQuery+C#实现参数RSA加密传输功能,结合具体实例形式分析了js使用jsencrypt.js插件前端字符数据处理传输及C#后台数据转换与RSA加密相关操作技巧,并附带jsencrypt.js供读者下载参考使用,需要的朋友可以参考下

随机推荐

  1. c# – (wpf)Application.Current.Resources vs FindResource

    所以,我正在使用C#中的WPF创建一个GUI.它看起来像这样:它现在还没有完成.这两行是我尝试制作一种数据表,它们在XAML中是硬编码的.现在,我正在C#中实现添加新的水果按钮功能.我在XAML中有以下样式来控制行的背景图像应该是什么样子:因此,在代码中,我为每列col0,col1和col2创建一个图像,如果我使用以下代码,它添加了一个如下所示的新行:如你所见,它不太正确……为什么一个似乎忽略了一些属性而另一个没有?

  2. c# – 绑定DataGridTemplateColumn

    似乎我已经打了个墙,试图在DataGrid上使用DataTemplates.我想要做的是使用一个模板来显示每个单元格的两行文本.但是似乎无法以任何方式绑定列.以下代码希望显示我想做的事情.注意每个列的绑定:模板列没有这样的东西,因此,这个xaml不可能工作.我注定要将整个DataTemplate复制到每个列,只是对每个副本都有不同的约束?解决方法我不完全确定你想要做什么,但如果您需要获取整行的DataContext,可以使用RelativeSource绑定来移动视觉树.像这样:

  3. c# – 学习设计模式的资源

    最近我来到了这个设计模式的概念,并对此感到非常热情.你能建议一些帮助我深入设计模式的资源吗?

  4. c# – 是否有支持嵌入HTML页面的跨操作系统GUI框架?

    我想开发一个桌面应用程序来使用跨系统,是否有一个GUI框架,允许我为所有3个平台编写一次代码,并具有完全可脚本化的嵌入式Web组件?我需要它有一个API来在应用程序和网页之间进行交流.我知道C#,JavaScript和一些python.解决方法Qt有这样的事情QWebView.

  5. c# – 通过字符串在对象图中查找属性

    我试图使用任意字符串访问嵌套类结构的各个部分.给出以下(设计的)类:我想要从Person对象的一个实例的“PersonsAddress.HousePhone.Number”获取对象.目前我正在使用反思来做一些简单的递归查找,但是我希望有一些忍者有更好的想法.作为参考,这里是我开发的(crappy)方法:解决方法您可以简单地使用标准的.NETDataBinder.EvalMethod,像这样:

  6. c# – 文件下载后更新页面

    FamilyID=0a391abd-25c1-4fc0-919f-b21f31ab88b7&displaylang=en&pf=true它呈现该页面,然后使用以下元刷新标签来实际向用户提供要下载的文件:你可能需要在你的应用程序中做类似的事情.但是,如果您真的有兴趣在文件完全下载后执行某些操作,那么您的运气不佳,因为没有任何事件可以与浏览器进行通信.执行此操作的唯一方法是上传附件时使用的AJAXupload.

  7. c# – 如何在每个机器应用程序中实现单个实例?

    我必须限制我的.net4WPF应用程序,以便每台机器只能运行一次.请注意,我说每个机器,而不是每个会话.我使用一个简单的互斥体实现单实例应用程序,直到现在,但不幸的是,这样一个互斥是每个会话.有没有办法创建机器互连,还是有其他解决方案来实现每个机器应用程序的单个实例?

  8. c# – WCF和多个主机头

    我的雇主网站有多个主机名,都是同一个服务器,我们只是显示不同的皮肤来进行品牌宣传.不幸的是,在这种情况下,WCF似乎不能很好地工作.我试过overridingthedefaulthostwithacustomhostfactory.这不是一个可以接受的解决方案,因为它需要从所有主机工作,而不仅仅是1.我也看过thisblogpost,但是我无法让它工作,或者不是为了解决我的问题.我得到的错误是“这

  9. c# – ASP.NET MVC模型绑定与表单元素名称中的虚线

    我一直在搜索互联网,试图找到一种方式来容纳我的表单元素的破折号到ASP.NET的控制器在MVC2,3或甚至4中的默认模型绑定行为.作为一名前端开发人员,我更喜欢在我的CSS中使用camelCase或下划线进行破折号.在我的标记中,我想要做的是这样的:在控制器中,我会传入一个C#对象,看起来像这样:有没有办法通过一些正则表达式或其他行为来扩展Controller类来适应这种情况?我讨厌这样的事实,我必须这样做:甚至这个:思考?

  10. c# – 用户界面设计工具

    我正在寻找一个用户界面设计工具来显示文档中可能的GUI.我不能生成代码.我知道MicrosoftVisio提供了一个功能.但有什么办法吗?您使用哪种软件可视化GUI?

返回
顶部