- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我想找到 N 个字符串的最长公共(public)子序列。我得到了对 2 个字符串使用动态编程的算法,但是如果我将它扩展到 N,它将消耗指数数量的内存,因为我需要一个 N 维数组。这不是一个选项。
在一般情况下 (90%),几乎所有字符串都是相同的。
如果我尝试将我的 N 个序列分解为 N/2 对,每对 2 个字符串,对每对分别运行 2 个字符串的 LCS,我将得到 N/2 个子序列。我可以删除重复项并重复此过程,直到我只有一个子序列,它对输入中的所有字符串都是通用的。
有什么我想念的吗?它看起来不像是 N 难问题的解决方案...
我知道每次使用每对字符串调用 LCS 可能有多个子序列作为解决方案,但如果我只得到这些子序列中的一个作为下一次调用的输入,也许我的最终子序列-sequence 不是最长的,但我有一些可能适合我的需要。
如果我尝试对一对使用所有可能的解决方案,然后与另一对的所有可能解决方案组合(每个对可能也有多个),我可能会以指数时间结束。我说得对吗?
最佳答案
是的,您错过了正确性:无法保证一对字符串的 LCS 与整个字符串的 LCS 有任何重叠。考虑这个例子:
aaabb1xyz
aaabb2xyz
cccdd1xyz
cccdd2xyz
如果您按照给定的顺序将它们配对,您将获得 aaabb
和 cccdd
的 LCS,缺少该集合的 xyz
。
如果像您所说的那样,字符串几乎完全相同,那么差异对您来说可能不是问题。如果不相同的字符串与“中值”字符串非常相似,那么您的增量解决方案就可以很好地满足您的目的。
另一种可能性是对随机字符串对进行 LCS,直到出现中值字符串;然后你从那个共同点开始,你应该有一个“足够好”的解决方案。
关于algorithm - N序列的最长公共(public)子序列(不同用途),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47062351/
XML可以应用于 WEB 开发的许多方面,常用于简化数据的存储和共享 XML 把数据从 HTML 分离 现在的HTML 文档一般都是显示动态数据,每当数据改变时将花费大量的时间来编辑 HTML
在类(class)(方案)中,我们最近学习了允许函数接受任意数量参数的语法,例如; (define len (lambda args (length args))) >(len 1 2 3
在 redis-cli 中执行 info 命令时,会列出与该服务器相关的所有信息。 “evicted_keys”的目的是什么? 最佳答案 Redis 可以配置为根据需要自动清除键。如果这样配置,red
golang 空结构体 struct{} 可以用来节省内存 ? 1
有人可以解释一下资源文件夹中的 Info.plist 是什么吗?我如何在我的应用程序中使用它?提前致谢。 最佳答案 您可以在Info.plist文件中为所有类型的设备指定不同的常规资源和应用程序配置,
我需要减小可执行文件的大小,并且经常在我的可执行文件中将某些“不必要的” uses占用一定的大小。 例如: Unit1连接到Unit2,但是两个单元的导入为“ System.SysUtils”。 然后
我是 OOP 的新手。虽然我了解多态是什么,但我无法真正使用它。我可以有不同名称的函数。为什么我应该尝试在我的应用程序中实现多态性。 最佳答案 在严格类型化的语言中,多态性对于拥有不同类型对象的列表/
Possible Duplicate: What is the difference between a delegate and events? Possible Duplicate: Differ
这个问题在这里已经有了答案: Custom index.html javadoc page? (2 个答案) 关闭 7 年前。 我使用的是eclipse。一般情况下我们可以使用javadoc.exe
你能解释一下吗ValidateAntiForgeryToken目的并向我展示有关 MVC 4 中的 ValidateAntiForgeryToken 的示例? 我找不到任何解释此属性的示例? 最佳答案
我正在学习 RxSwift 并试图了解 Observable 和 PublishSubject aka Sequence 之间的主要区别。 据我了解,Sequences/PublishesSubjec
有时有人说,在使用 Azure 表时,实际上存在第三个关键分区数据 - 表名称本身。 我在执行分段查询时注意到 TableContinuationToken 有一个 NextTableName 属性。
在Apple提供的aurioTouch项目中,听说在performRender()函数下的AudioController文件中的AudioBufferList ioData携带了mic到音频播放器的音
MSDN 文档没有详细解释它的用途。 由于它是可选的,我几乎假设它类似于某种元数据。 我现在如何看待它,我想用它来为特定用户指定缓存,例如: new CacheItem(key: "keyName",
我正在学习 browserify,我正在尝试用它做两件基本的事情: 转换(通过 shim)非 CommonJS 模块以实现易用性和依赖跟踪 捆绑项目特定的库 我找到了一个工作流程,说明如何使用 Gul
我通过按 CTRL + C 访问 eix 1.8.2 的 Break 菜单。它看起来像这样: BREAK: (a)bort (c)ontinue (p)roc info (i)nfo (l)oaded
在 codeLabs 教程(Android - Kotlin - Room with a View)中,他们使用“viewModelScope.launch(Dispatchers.IO)”来调用插入
我通过按 CTRL + C 访问 eix 1.8.2 的 Break 菜单。它看起来像这样: BREAK: (a)bort (c)ontinue (p)roc info (i)nfo (l)oaded
请耐心等待,因为我没有太多地使用压缩算法,所以这对你们中的一些人来说可能是显而易见的。当某些流媒体视频开始滞后时,我总是注意到这一点。当我看到这个问题时我才意识到我很好奇: Twitter image
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 3 年前。 Improv
我是一名优秀的程序员,十分优秀!