- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
给定一个包含 n 个字符串的列表 L 和一个输入字符串 S,找到 L 中包含 S 中存在的最多字符的字符串的有效方法是什么?我们想在 L 中找到与 S 中包含的字母最接近的字符串。
显而易见的答案是遍历所有n个字符串,并检查当前字符串中有多少个字符存在于S中。但是这个算法会被频繁运行,n个字符串的列表L将存储在数据库中...手动遍历所有 n 个字符串需要类似于 n*m^2 的 big-Oh,其中 n 是 L 中的字符串数,m 是 L 中任何字符串的最大长度,以及最大长度S 的长度...在这种情况下,m 实际上是一个常数 150。
有没有比简单循环更好的方法?是否有一种数据结构可以将 n 个字符串加载到其中,从而提供快速搜索能力?是否有一种算法使用关于 n 个字符串中的每一个的预先计算的元数据,其性能会比循环更好?
我知道有很多极客都热衷于算法。所以请帮忙!
谢谢!
最佳答案
如果你在子串之后,一个Trie或者 Patrica trie 可能是一个很好的起点。
如果你不关心顺序,只关心每个符号或字母的数量,我会计算所有字符串的直方图,然后将它们与输入的直方图进行比较。
ABCDEFGHIJKLMNOPQRSTUVWXYZ
Hello World => ...11..1...3..2..1....1...
如果您只考虑不区分大小写的拉丁字母,这会将成本降低到 O(26 * m + n)
加上一次预处理。
如果 m 是常量,您可以通过对其进行归一化,将直方图解释为 26 维单位球体上的 26 维向量。然后你可以计算Dot Product两个向量的夹角的余弦值,这个值应该与字符串的相似度成正比。
假设 m = 3
,字母表 A = { 'U', 'V', 'W' }
只有三个大小,以及以下字符串列表.
L = { "UUU", "UVW", "WUU" }
直方图如下。
H = { (3, 0, 0), (1, 1, 1), (2, 0, 1) }
直方图 h = (x, y, z)
归一化为 h' = (x/r, y/r, z/r)
和 r
直方图 h
的欧几里德范数 - 即 r = sqrt(x² + y² + z²)
。
H' = { (1.000, 0.000, 0.000), (0.577, 0.577, 0.577), (0.894, 0.000, 0.447) }
输入 S = "VVW"
具有直方图 hs = (0, 2, 1)
和归一化直方图 hs' = (0.000, 0.894 , 0.447)
。
现在我们可以计算两个直方图h1 = (a, b, c)
和h2 = (x, y, z)
的相似度作为欧式距离两个直方图。
d(h1, h2) = sqrt((a - x)² + (b - y)² + (c - z)²)
对于我们得到的例子。
d((3, 0, 0), (0, 2, 1)) = 3.742
d((1, 1, 1), (0, 2, 1)) = 1.414
d((2, 0, 1), (0, 2, 1)) = 2.828
因此“UVW”最接近“VVW”(数字越小表示相似度越高)。
使用归一化直方图 h1' = (a', b', c')
和 h2' = (x', y', z')
我们可以将距离计算为两个直方图的点积。
d'(h1', h2') = a'x' + b'y' + c'z'
对于我们得到的例子。
d'((1.000, 0.000, 0.000), (0.000, 0.894, 0.447)) = 0.000
d'((0.577, 0.577, 0.577), (0.000, 0.894, 0.447)) = 0.774
d'((0.894, 0.000, 0.447), (0.000, 0.894, 0.447)) = 0.200
再次确定“UVW”最接近“VVW”(数字越大表示相似度越高)。
两个版本产生不同的数字,但结果总是相同的。也可以使用其他范数——例如曼哈顿距离(L1 范数)——但这只会改变数字,因为有限维向量空间中的范数都是等价的。
关于使用相同字符查找最接近字符串的算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/859441/
是 if(a == 0 && b == 0 && c == 0) { return; } 一样 if(a == 0) { return; } if(b == 0) { return; } if(c =
我想做这样的事情: Class A Class B extends A Class C extends A B b = new B(); C c = new C(); b->setField("foo
我对 Mysql 世界很天真......:)我试图使用连接从表中查询, 我遇到结果集问题...表结构如下 下面... VIDEO_XXXXX | Field | Type
我最近问过关于从另一个类获取类的唯一实例的问题。 ( How to get specific instance of class from another class in Java? ) 所以,我正
假设我们有两种类型 using t1 = int*; using t2 = int*; 我知道 std::is_same::value会给我们true .什么是,或者是否有模板工具可以实现以下目标?
对于我的一个应用程序,我假设比较 2 个字符串的第一个字符比比较整个字符串是否相等要快。例如,如果我知道只有 2 个可能的字符串(在一组 n 字符串中)可以以相同的字母开头(比如说 'q'),如果是这
我想在我的NXP LPC11U37H主板(ARM Cortex-M0)上分析一些算法,因为我想知道执行特定算法需要多少个时钟周期。 我编写了这些简单的宏来进行一些分析: #define START_C
我在 Excel 中创建了一个宏,它将在 Excel 中复制一个表格,并将行除以我确定的特定数字(默认 = 500 行),并为宏创建的每个部门打开不同的工作表。 使用的代码是这样的: Sub Copy
我想根据第一个字典对第二个字典的值求和。如果我有字典 A 和 B。 A = {"Mark": ["a", "b", "c", "d"], "June": ["e", "a"], "John": ["a
当我这样做时 system()在 Perl 中调用,我通常根据 perldocs 检查返回码.嗯,我是这么想的。大部分时间 $rc!=0对我来说已经足够了。最近我在这里帮助了两个遇到问题的人syste
在我的进度条上,我试图让它检测 div 加载速度。 如果 div 加载速度很快,我想要实现的目标将很快达到 100%。但进度条的加载速度应该与 div 的加载速度一样快。 问题:如何让我的进度条加载
当我获得与本地时间相同的时间戳时,firebase 生成的服务器时间戳是否会自动转换为本地时间,或者我错过了什么? _firestore.collection("9213903123").docume
根据the original OWL definition of OWL DL ,我们不能为类和个体赋予相同的名称(这是 OWL DL 和 OWL Full 之间的明显区别)。 "Punning" i
我有两个输入复选框: 尝试使用 jQuery 来允许两个输入的行为相同。如果选中第一个复选框,则选中第二个复选框。如果未检查第 1 个,则不会检查第 2 个。反之亦然。 我有代码: $('inpu
可以从不同系统编译两个相同的java文件,但它们都有相同的内容操作系统(Windows 7),会生成不同的.class文件(大小)? 最佳答案 是的,您可以检查是否有不同版本的JDK(Java Dev
我正在清理另一个人的正则表达式,他们目前所有的都以结尾 .*$ 那么下面的不是完全一样吗? .* 最佳答案 .*将尽可能匹配,但默认情况下为 .不匹配换行符。如果您要匹配的文本有换行符并且您处于 MU
我使用 Pick ,但是如何编写可以选择多个字段的通用PickMulti呢? interface MyInterface { a: number, b: number, c: number
我有一个 SQL 数据库服务器和 2 个具有相同结构和数据的数据库。我在 2 个数据库中运行相同的 sql 查询,其中一个需要更长的时间,而另一个在不到 50% 的时间内完成。他们都有不同的执行计划。
我需要你的帮助,我有一个包含两列的表,一个 id 和 numpos,我希望 id 和 numops 具有相同的结果。 例子: $cnx = mysql_connect( "localhost", "r
如何将相同的列(在本例中按“级别”排序)放在一起?我正在做一个高分,我从我的数据库中按级别列出它们。如果他们处于同一级别,我希望他们具有相同的 ID。 但是我不想在别人身上显示ID。只有第一个。这是一
我是一名优秀的程序员,十分优秀!