一般问题:
我有一个很大的2d点空间,人口稀少。
认为它是一个大的白色画布上撒上黑点。
我必须遍历并搜索这些点很多。
帆布(点空间)可以是巨大的,接近极限
int和它的大小在设置点之前是未知的。

这带来了哈希的想法:

理想:
我需要一个采用2D点的哈希函数,返回一个唯一的uint32。
所以不会发生碰撞。你可以假设的数量
画布上的点很容易被uint32计数。

重要事项:事先无法知道画布的大小
(甚至可能会改变)
所以这样的东西

canvaswidth * y x

很遗憾的是这个问题。

我也尝试了一个非常幼稚的

abs(x)abs(y)

但是会产生太多的冲突。

妥协:
一个散列函数,提供非常低的碰撞概率的键。

有什么想法吗感谢任何帮助。

最好的祝福,
安德烈亚斯

编辑:
我不得不在问题文本中改变一些东西:
我改变了“能够计算画布点数”的假设
与uint32“成”能够计数画布上的点(或要存储的坐标对的数量)由uint32。
我原来的问题没有什么意义,因为我会有一个sqrt(max(uint32))xsqrt(max(uint32))大小的画布,这是独一无二的
通过16位移位和OR。

我希望这是可以的,因为所有答案对于更新的假设仍然是最有意义的

对不起,

保证无碰撞的哈希函数不是散列函数:)

您可以考虑使用二进制空间分区树(BSP)或XY树(密切相关)来代替使​​用散列函数。

如果要将两个uint32的哈希值混合成一个uint32,不要使用像Y& 0xFFFF因为丢弃一半的位。做某事

(x * 0x1f1f1f1f) ^ y

(您需要首先转换一个变量,以确保哈希函数不可交换)

散列函数从整数坐标对提供唯一的uint的更多相关文章

  1. 散列函数从整数坐标对提供唯一的uint

    认为它是一个大的白色画布上撒上黑点。这带来了哈希的想法:理想:我需要一个采用2D点的哈希函数,返回一个唯一的uint32。你可以假设的数量画布上的点很容易被uint32计数。最好的祝福,安德烈亚斯编辑:我不得不在问题文本中改变一些东西:我改变了“能够计算画布点数”的假设与uint32“成”能够计数画布上的点由uint32。如果要将两个uint32的哈希值混合成一个uint32,不要使用像Y&0xFFFF因为丢弃一半的位。

  2. php – MySQL散列函数实现

    我本来在这个问题上偶然发现我自己寻找一个PHP实现的两个MysqL密码哈希函数.我无法找到任何实现,所以我自己从MysqL源代码修改了自己.以下测试和工作在PHP5.2:希望别人会发现这个有用的:)

  3. java – 一个好的哈希函数,用于访问整数,字符串?

    我在面试中遇到了一些情况,我需要使用整数或字符串的哈希函数.在这种情况下,我们应该选择哪些?我在这些情况下出错了,因为我最终选择了那些产生大量碰撞的东西,然后哈希函数往往是数学的,你不能在面试中回忆一下.有没有一般的建议,至少面试官对你的整数或字符串输入的方法感到满意?如果相等的实例具有不等的哈希码,可以弄清楚为什么并解决问题.

  4. 散列表实现的哈希算法

    我正在寻找具有良好分布的高速散列函数,用于散列表实现.散列表将专门用于存储具有整数键的值.我可以使用整数的较低几位作为哈希吗?例如intkey=n&15;并创建一个带有16个插槽的阵列来存储它们.任何建议?解决方法你可以看这里xxhash你提到的哈希函数非常快,但它也是非常糟糕的.如果你想要一个“愚蠢”的哈希函数,也许你可以考虑模数.例:

  5. 哈希表 – 分析目标并选择一个好的哈希函数

    让我们来谈谈哈希函数,以及如何选择哈希函数.如果一个编程菜鸟需要为他们的特定任务选择一个好的哈希函数,那么选择一个呢?

  6. c – 悲惨的unordered_map插入性能/散列函数

    尽管图像中的重复颜色数量非常少.之后,我想消除代码中的任何可能的错误,并开始使用带有原始键类型的STL哈希函数对unordered_map进行基准测试.该基准的代码是:…STL库通常具有高质量,但对于简单的基于int的键音具有639/640和640/1280至少是奇怪的.或者也许我做错了什么?这是我的哈希函数:现在,这不再有趣了……我写了这个哈希函数:从理论上讲,我应该有100%的碰撞率,对吗?

  7. 将C#散列函数转换为PHP

    )或者更可能首先转换为其他东西.在这种情况下,可能是unicode,它绝对不是字符串与.net请求的字符串相同的字节.我的建议是确保PHP也使用ASCII,withiconv,以实现互操作性.我不能确定上面的代码会输出所需的哈希值,但是,因为我没有.net方便测试初始代码.但这可能会指向正确的方向.如果这不起作用,iconv_get_encoding中的值(可能是罪魁祸首,请尝试“output_encoding”或“input_encoding”.您也可能需要使用iconv_set_encoding(.)

  8. c# – 反转哈希函数

    我有以下哈希函数,我试图让我的方法来反转它,以便我可以从哈希值中找到密钥.代码在C#中,但我认为很清楚.我知道,对于一个散列值,可以有多个键,但我的意图不是找到它们,只需要满足散列函数就足够了.编辑:函数接受的字符串仅由数字0到9以及字符’*’和’#’组成,因此Unhash函数也必须遵守此条件.有任何想法吗?

  9. c – unordered_map – 哈希函数没有影响

    为什么在下面的哈希函数似乎没有任何效果?解决方法你误解了使用哈希函数:它不用于比较元素.在内部,地图将元素组织成桶,散列函数用于确定元素所在的桶.使用另一个模板参数执行元素的比较,查看unordered_map模板的完整声明:后面的模板参数是hasher后的关键比较器.要获得您期望的行为,您必须执行以下操作:现在你的地图将有一个单一的元素,所有的结果将是3.

  10. c – 您将如何设计一个完美散列函数?

    感兴趣的领域是字符串匹配.假设我有这样的结构.数组中有固定数量的字符串.它们是硬编码的,如在示例中.如果表改变,则需要重新评估散列函数的质量.我想对一个字符串应用一个哈希函数,如果字符串匹配一个数组,然后调用该函数.需要一个完美的哈希函数.不允许碰撞.要求散列的目的是在查找中获得O性能.你有什么想法来设计功能来做到这一点?解决方法请参阅gperf主页.

随机推荐

  1. static – 在页面之间共享数据的最佳实践

    我想知道在UWP的页面之间发送像’selectedItem’等变量的最佳做法是什么?创建一个每个页面都知道的静态全局变量类是一个好主意吗?

  2. .net – 为Windows窗体控件提供百分比宽度/高度

    WindowsForm开发的新手,但在Web开发方面经验丰富.有没有办法为Windows窗体控件指定百分比宽度/高度,以便在用户调整窗口大小时扩展/缩小?当窗口调整大小时,可以编写代码来改变控件的宽度/高度,但我希望有更好的方法,比如在HTML/CSS中.在那儿?

  3. 使用Windows Azure查询表存储数据

    我需要使用特定帐户吗?>将应用程序部署到Azure服务后,如何查询数据?GoogleAppEngine有一个数据查看器/查询工具,Azure有类似的东西吗?>您可以看到的sqlExpressintance仅在开发结构中,并且一旦您表示没有等效,所以请小心使用它.>您可以尝试使用Linqpad查询表格.看看JamieThomson的thispost.

  4. windows – SetupDiGetClassDevs是否与文档中的设备实例ID一起使用?

    有没有更好的方法可以使用DBT_DEVICEARRIVAL事件中的数据获取设备的更多信息?您似乎必须指定DIGCF_ALLCLASSES标志以查找与给定设备实例ID匹配的所有类,或者指定ClassGuid并使用DIGCF_DEFAULT标志.这对我有用:带输出:

  5. Windows Live ID是OpenID提供商吗?

    不,WindowsLiveID不是OpenID提供商.他们使用专有协议.自从他们的“测试版”期结束以来,他们从未宣布计划继续它.

  6. 如果我在代码中进行了更改,是否需要重新安装Windows服务?

    我写了一个Windows服务并安装它.现在我对代码进行了一些更改并重新构建了解决方案.我还应该重新安装服务吗?不,只需停止它,替换文件,然后重新启动它.

  7. 带有双引号的字符串回显使用Windows批处理输出文件

    我正在尝试使用Windows批处理文件重写配置文件.我循环遍历文件的行并查找我想要用指定的新行替换的行.我有一个’函数’将行写入文件问题是%Text%是一个嵌入双引号的字符串.然后失败了.可能还有其他角色也会导致失败.如何才能使用配置文件中的所有文本?尝试将所有“在文本中替换为^”.^是转义字符,因此“将被视为常规字符你可以尝试以下方法:其他可能导致错误的字符是:

  8. .net – 将控制台应用程序转换为服务?

    我正在寻找不同的优势/劣势,将我们长期使用的控制台应用程序转换为Windows服务.我们为ActiveMQ使用了一个叫做java服务包装器的东西,我相信人们告诉我你可以用它包装任何东西.这并不是说你应该用它包装任何东西;我们遇到了这个问题.控制台应用程序是一个.NET控制台应用程序,默认情况下会将大量信息记录到控制台,尽管这是可配置的.任何推荐?我们应该在VisualStudio中将其重建为服务吗?我使用“-install”/“-uninstall”开关执行此操作.例如,seehere.

  9. windows – 捕获外部程序的STDOUT和STDERR *同时*它正在执行(Ruby)

    哦,我在Windows上:-(实际上,它比我想象的要简单,这看起来很完美:…是的,它适用于Windows!

  10. windows – 当我试图批量打印变量时,为什么我得到“Echo is on”

    我想要执行一个简单的批处理文件脚本:当我在XP中运行时,它给了我预期的输出,但是当我在Vista或Windows7中运行它时,我在尝试打印值时得到“EchoisOn”.以下是程序的输出:摆脱集合表达式中的空格.等号(=)的两侧可以并且应该没有空格BTW:我通常在@echo关闭的情况下启动所有批处理文件,并以@echo结束它们,所以我可以避免将代码与批处理文件的输出混合.它只是使您的批处理文件输出更好,更清洁.

返回
顶部