- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
让我解释一下我的程序。它是一个魔方求解器。我得到一个加扰的立方体(这是初始状态)。这成为图的根节点。我正在使用 iterative deepening depth first search
将这个打乱的立方体“暴力破解”到可识别的状态,然后我可以使用模式识别来解决。
您可以想象,这是一个非常大的图,所以我想提出某种散列功能来检测该图中的重复节点(从而加快遍历速度)。
我对散列函数基本不熟悉,但这是我的想法……每个节点本质上都是魔方的不同状态。所以如果我来到一个已经看到的立方体状态(节点),我想跳过它。所以我需要一个散列函数,将我从状态变量带到校验和,其中状态变量是一个 54 个字符的字符串。唯一允许的字符是 y, r, g, o, b, w
(对应于颜色)。
任何帮助设计此哈希函数将不胜感激。
最佳答案
为了最快的重复检测和删除 - 首先避免生成许多重复的位置。这比生成然后查找重复更容易并且更快。因此,例如,如果您有 F 和 B 之类的移动,如果您允许子序列 FB 也不允许 BF,这会给出相同的结果。如果您刚刚完成 3F,请不要跟随 F。您可以生成一个小的查找表,用于在给定最后三个 Action 的情况下允许下一步 Action 。
对于剩余的重复项,您需要快速散列,因为位置很多。正如其他人所评论的那样,为了使您的哈希值更快,您希望它的哈希值来自,即位置的表示,要小。有 12 个边角 block 和 8 个角 block 。表示每个立方体的位置和方向只需每个立方体 5 位,即总共 100 位(12.5 字节)。对于边缘,它的四位用于位置,一位用于翻转。对于角,它的三位代表位置,2 位代表自旋。你可以忽略最后一个边缘立方体,因为它的位置和翻转是由其他人固定的。使用这种表示形式,您的位置已经减少到 12 个字节。
你在一个魔方位置有大约 70 个真实位的信息,而 96 位足够接近 70 位,因此实际上对这些位进行进一步的散列运算会适得其反。 IE。将此板的表示视为您的哈希。这听起来可能有点奇怪,但是从您的问题来看,我设想您同时尝试使用更适合您的模式匹配的立方体的不太紧凑的表示。在这种情况下,12 字节的值可以被视为散列,其优点是它是永远不会发生冲突的散列。这使得重复测试代码和新值插入更短、更简单、更快。它会比目前建议的 MD5 解决方案便宜。
您可以使用许多其他技巧来减少搜索重复位置的工作量。看看http://cube20.org/想法。
关于hash - 帮助设计一个散列函数来检测重复记录?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4338200/
C语言sscanf()函数:从字符串中读取指定格式的数据 头文件: ?
最近,我有一个关于工作预评估的问题,即使查询了每个功能的工作原理,我也不知道如何解决。这是一个伪代码。 下面是一个名为foo()的函数,该函数将被传递一个值并返回一个值。如果将以下值传递给foo函数,
CStr 函数 返回表达式,该表达式已被转换为 String 子类型的 Variant。 CStr(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CSng 函数 返回表达式,该表达式已被转换为 Single 子类型的 Variant。 CSng(expression) expression 参数是任意有效的表达式。 说明 通常,可
CreateObject 函数 创建并返回对 Automation 对象的引用。 CreateObject(servername.typename [, location]) 参数 serv
Cos 函数 返回某个角的余弦值。 Cos(number) number 参数可以是任何将某个角表示为弧度的有效数值表达式。 说明 Cos 函数取某个角并返回直角三角形两边的比值。此比值是
CLng 函数 返回表达式,此表达式已被转换为 Long 子类型的 Variant。 CLng(expression) expression 参数是任意有效的表达式。 说明 通常,您可以使
CInt 函数 返回表达式,此表达式已被转换为 Integer 子类型的 Variant。 CInt(expression) expression 参数是任意有效的表达式。 说明 通常,可
Chr 函数 返回与指定的 ANSI 字符代码相对应的字符。 Chr(charcode) charcode 参数是可以标识字符的数字。 说明 从 0 到 31 的数字表示标准的不可打印的
CDbl 函数 返回表达式,此表达式已被转换为 Double 子类型的 Variant。 CDbl(expression) expression 参数是任意有效的表达式。 说明 通常,您可
CDate 函数 返回表达式,此表达式已被转换为 Date 子类型的 Variant。 CDate(date) date 参数是任意有效的日期表达式。 说明 IsDate 函数用于判断 d
CCur 函数 返回表达式,此表达式已被转换为 Currency 子类型的 Variant。 CCur(expression) expression 参数是任意有效的表达式。 说明 通常,
CByte 函数 返回表达式,此表达式已被转换为 Byte 子类型的 Variant。 CByte(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CBool 函数 返回表达式,此表达式已转换为 Boolean 子类型的 Variant。 CBool(expression) expression 是任意有效的表达式。 说明 如果 ex
Atn 函数 返回数值的反正切值。 Atn(number) number 参数可以是任意有效的数值表达式。 说明 Atn 函数计算直角三角形两个边的比值 (number) 并返回对应角的弧
Asc 函数 返回与字符串的第一个字母对应的 ANSI 字符代码。 Asc(string) string 参数是任意有效的字符串表达式。如果 string 参数未包含字符,则将发生运行时错误。
Array 函数 返回包含数组的 Variant。 Array(arglist) arglist 参数是赋给包含在 Variant 中的数组元素的值的列表(用逗号分隔)。如果没有指定此参数,则
Abs 函数 返回数字的绝对值。 Abs(number) number 参数可以是任意有效的数值表达式。如果 number 包含 Null,则返回 Null;如果是未初始化变量,则返回 0。
FormatPercent 函数 返回表达式,此表达式已被格式化为尾随有 % 符号的百分比(乘以 100 )。 FormatPercent(expression[,NumDigitsAfterD
FormatNumber 函数 返回表达式,此表达式已被格式化为数值。 FormatNumber( expression [,NumDigitsAfterDecimal [,Inc
我是一名优秀的程序员,十分优秀!