- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在研究一个代码挑战问题——“找到幸运的三元组”。 “幸运三元组”定义为“在列表 lst
中,对于像 (lst[i], lst[j], lst[k]) where i < j < k
这样的三元组的任意组合,其中 lst[i] divides lst[j]
和 lst[j] divides lst[k]
。
我的任务是找出给定列表中幸运三元组的数量。蛮力方法是使用三个循环,但解决问题需要花费太多时间。我写了这个,系统响应“超时”。这些问题看起来愚蠢而简单,但数组未排序,因此二分查找等一般方法不起作用。我被这个问题惊呆了一天,希望有人能给我一个提示。我正在寻求一种更快地解决问题的方法,至少时间复杂度应该低于 O(N^3)。
最佳答案
一个简单的类似动态规划的算法将在二次时间和线性空间中执行此操作。你只需要维护一个计数器 c[i]
对于列表中的每个项目,它表示将 L[i]
整除的先前整数的数量.
然后,当您浏览列表并测试每个整数时 L[k]
与所有之前的项目 L[j]
, 如果 L[j]
划分 L[k]
,您只需添加 c[j]
(可能是 0)到你的三元组的全局计数器,因为这也意味着恰好存在 c[j]
项目 L[i]
这样 L[i]
划分 L[j]
和 i < j
.
int c[] = {0}
int nbTriples = 0
for k=0 to n-1
for j=0 to k-1
if (L[k] % L[j] == 0)
c[k]++
nbTriples += c[j]
return nbTriples
可能有一些更好的算法使用奇特的离散数学来更快地完成它,但如果 O(n^2) 没问题,这就可以了。
关于您的评论:
为什么是 DP?我们有一些东西可以清楚地建模为具有从左到右的顺序(DP 橙色标志),感觉就像重用以前计算的值可能会很有趣,因为蛮力算法会多次执行完全相同的计算。
如何从中得出解决方案?运行一个简单的示例(提示:最好从左到右处理输入)。在步骤i
,计算你可以从这个特定点计算出的东西(忽略 i 右边的所有东西),并尝试针对不同的 i's
一遍又一遍地查明你计算的东西。 : 这是你想要缓存的。在这里,当您在 k
步看到一个潜在的三元组时( L[k] % L[j] == 0
),你必须考虑 L[j]
上会发生什么:“它的左边是否也有一些除数?每一个都会给我们一个新的三元组。让我们看看......但是等等!我们已经在步骤 j
中计算了它!让我们缓存这个值!”这就是你跳到座位上的时候。
关于algorithm - 有没有更快的方法找到 "lucky triples"的数量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39715457/
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
在现代 IDE 中,有一个键盘快捷键可以通过键入文件名称来打开文件,而无需将手放在鼠标上。例如: Eclipse:Cmd|Ctrl + Shift + R -> 打开资源 IntelliJ:Cmd|C
有什么东西会等待事件发生(我正在等待的是 WebBrowser.DocumentCompleted),然后执行代码吗?像这样: If (WebBrowser.DocumentCompleted) 不会
我使用 PHP Minify,它很棒。但我的问题是,是否有任何 PHP 插件或其他东西可以自动检测 javascript/css 代码并自动缩小它?谢谢。 最佳答案 Javascript 压缩器? 看
有没有一种语言,类似什么CoffeeScript是JavaScript,编译成windows batch|cmd|command line的语言? 我指的cmd版本是基于NT的,尤其是XP sp3及以
我知道我可以 ,但是,我真的宁愿有一个任务,我可以从任何可以使用所有(或至少大部分)属性的操作系统调用 copy ,但这并没有消除 unix 上的权限。 我想知道是否已经有解决方案,或者我必须自己编
我正在使用 Vuejs(不使用 jQuery)开发一个项目,该项目需要像 jvectormap 这样的 map 但正如我所说,我没有使用 jQuery,那么是否有任何其他库可以在不使用 jQuery
想要进行一个简单的民意调查,甚至不需要基于 cookie,我不在乎投了多少票。有没有类似的插件或者简单的东西? 最佳答案 这是一个有用的教程 - 让我知道它是否适合您 using jQuery to
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
var FileBuff: TBytes; Pattern: TBytes; begin FileBuff := filetobytes(filename); Result := Co
我想要一个 vqmod xml 文件来添加一次上传多个图像的功能。身边有这样的事吗? 编辑:Opencart版本:2.1.0.1 最佳答案 最后我写了一个xml来添加到opencart 2.1.0.1
所以考虑这样的函数: public void setTemperature(double newTemperatureValue, TemperatureUnit unit) 其中Temperatur
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我是 ggplot2 的新手,一直在尝试找到一个全面的美学列表。我想我理解它们的目的,但很难知道哪些可以在各种情况下使用(主要是几何图形?)。 Hadley 的网站偶尔会在各个几何图形的页面上列出可用
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
是否有任何 PHP 函数可以将整数转换为十万和千万? 900800 -> 9,00,800 500800 -> 5,00,800 最佳答案 由于您已在问题标签中添加了 Yii,因此您可以按照 Yii
使用 Clojure 一段时间后,我积累了一些关于它的惰性的知识。我知道诸如map之类的常用API是否是惰性的。然而,当我开始使用一个不熟悉的API(例如with-open)时,我仍然感到怀疑。 是否
我的项目需要一个像 AvalonDock 这样的对接系统,但它的最后一次更新似乎是在 2013 年 6 月。是否有更多...积极开发的东西可以代替它? 最佳答案 AvalonDock 实际上相当成熟并
我正在寻找一个可以逆转 clojure 打嗝的函数 所以 turns into [:html] 等等 根据@kotarak的回答,这现在对我有用: (use 'net.cgrand.enliv
我是一名优秀的程序员,十分优秀!