- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
抱歉,这是一个由三部分组成的问题。我一直在努力完成第一部分,我认为如果我完成了,其余部分就会到位,但我的运行时间不太合适。我知道有 n 次迭代,但不知道如何在不使用值 j 的情况下计算内循环的迭代次数
考虑以下基本问题。给定一个由 n 个整数 A[1]、A[2]、...A[n] 组成的数组 A。你想输出一个二维的n×n 数组 B,其中 B[i,j](对于 i =j,因此这些值的输出内容无关紧要。)这里有一个简单的算法来解决这个问题。
For i=1, 2,...,n
For j=i+1, i+2, ... n
Add up array entries A[i] through A[j]
Store the result in B[i,]]
Endfor
Endfor
(a) 对于您应该选择的某个函数 f,在大小为 n 的输入上给出此算法的运行时间的 O(f(n)) 形式的界限(即,数量的界限)算法执行的操作)。
(b) 对于同一个函数 f,证明算法在大小为 n 的输入上的运行时间也是 ~2 (f(n))。 (这显示了 ®(f(n)) 在运行时间上的渐近紧界。)
(c) 虽然你在 (a) 和 (b) 部分分析的算法是最解决问题的自然方法——毕竟,它只是遍历数组 B 的相关条目,为每个条目填充一个值——它包含一些非常不必要的低效率来源。给出一个不同的算法来解决这个问题,具有渐近更好的运行时间。换句话说,您应该设计一个运行时间为 O(g(n)) 的算法,其中 limn-->infinity g(n)/f(n) = O。
最佳答案
我将介绍第一部分。然后,您可能会很清楚地解决第二部分。第三个是一个完全独立的问题(因此,如果您需要帮助,也应该作为一个单独的问题发布)。
分析运行时间,可以从内部开始,逐渐向外
Add up array entries A[i] through A[j]
假设在条目上循环的直接实现,这将为您提供 j - i + 1
(抽象时间单位)的运行时间。确切的数字将取决于实现以及您如何计算操作。对于 O(*)
表示法,这不会有什么不同。我将保留这些特定时间,不会将它们简化为一些 O(*)
符号,因为您可能需要部分 (b) 的特定时间。
Store the result in B[i,j]
它的运行时间为 1
。因此,内部循环内的部分的运行时间为 j - i + 2
。我将用 T(j - i + 2)
替换代码。所以,我们留下的代码是:
For i=1, 2,...,n
For j=i+1, i+2, ... n
T(j - i + 2)
Endfor
Endfor
要找到内循环的运行时间,我们需要求解给定边界上的总和:Sum (for j from i+1 to n) (j - i + 2)
。它是一个算术级数,解为 1/2 * (i - n - 5) * (i - n)
。现在的代码是:
For i=1, 2,...,n
T(1/2 * (i - n - 5) * (i - n))
Endfor
再次求解和得到 1/6 * (n^3 + 6n^2 - 7n)
的最终运行时间。而这个函数在 O(n^3)
中。
关于arrays - 算法的运行时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52569889/
考虑以下示例代码: void main() { List array = []; for (int i = 0; i newList = array.where( (value) => v
我在java中实现了textrank,但它看起来很慢。有谁知道它的预期性能吗? 如果预计速度不会很慢,则可能是以下任一问题: 1) 似乎没有办法在 JGraphT 时间内创建一条边并同时为其添加权重,
我正在尝试提交解决方案(使用一些具有编译时间限制的在线编译器)来对数组进行排序 - 这是我的代码片段 - class TSORT { public static void main(Strin
只是一个困惑......部分C++示例代码如下 我只是重新编辑了整个帖子。抱歉造成任何混淆 int i, j; i = 0; // c1 j = 0; // c2 while (i
我正在使用 OpenMP 运行一些并行工作,但发现加速无法很好地扩展。然后我发现随着线程数量的增加,完成相同工作量的时间也会增加。这是示例: void fillingVec(vector& vec)
我目前正在分析 maximum subarray problem 用于强力算法和分而治之算法(递归)。 使用蛮力算法,最坏情况下的运行时间为 O(n^2)。使用递归算法,最坏情况下的运行时间为 O(n
如果我有两个数组都有 10000 个项目,现在我想将它们合并到一个数组中,所以我用 concat 来完成: array1=array1.concat(array2); 但是有人知道运行时间是多少吗?
{ clock_t t1, t2; double time1 = 0; t1 = clock(); bubbleSort(data, n); t2 = cloc
我在某处读到有人可以在运行时访问配置值,但不能在设计时访问。在这种情况下,运行时和设计时有什么区别? 最佳答案 设计时间是有人用愉快的“看起来不错!”在我们的 Word 文档和 UML 图表上签字的时
我正在比较我们一个项目的两个分支的性能,一个比另一个慢得多。我注意到其中一个的 GC 运行计数更高(见下图)。 更有趣的是,运行时间要长很多倍,远远超过额外运行所能解释的时间。什么可以解释运行次数增加
我想以可读的方式格式化 log4j 经过的运行时间,%r 参数: [00:36:25.844] 和 [01 13:35:25.844] [时:分:ss.SSS] ... [dd 时:分:ss.SSS]
如何计算此代码的大 O 运行时效率?我的直觉告诉我它是 O(n^3),但我不确定,因为我不确定循环是独立的还是相关的。 for (i=1; i<=n; i++) for (j=1; j<=n;
确定这些不同循环的大 O 运行时间? for i = 1 to n { ... for j = 1 to 2*i { ... k = j; while (k>=0)
运行时间、复杂性、编译时间和执行时间有什么区别? 运行时间与时间复杂度有冲突,执行时间和执行时间有什么区别? 最佳答案 您真正需要的是如何将大O时间复杂度转换为运行时。这不像一开始看起来那么容易。 因
斯内普的《Unfriendly Algorithms for Wizards》教科书声称合并的运行时间排序是 O(n^4)。这种说法是否正确? 解决方案:是的。这个说法在技术上是正确的,因为 O(n^
我有一系列问题需要反馈和答案。我会评论我的想法,这不是家庭作业而是准备为了我的考试。 我的主要问题是确定不同情况下循环的迭代。试图弄清楚这一点会如何? 评估运行时间。 Q2。 for(int i =
我试图找到一个合理的机会来测量我的 java 程序/程序部分的速度,例如测试两种方法中哪一种执行得更快。注释掉这两种方法中的一种,确定运行时间,最后比较时间。我不想在我的程序中使用任何代码,例如: p
好吧,这些都是非常简单的方法,而且有几个,所以当它们都是同一件事时,我不想只创建多个问题。 BigO 是我的弱点。我只是想不通他们是如何得出这些答案的。无论如何,您是否可以让我深入了解您对分析其中一些
如何计算此给定代码的 Theta 运行时间: void f(int n) { for (int i=3; i
使用 leiningen 创建 uberjar 并使用 java -jar foo-uberjar.jar 运行该 jar 后程序运行良好,最后一行代码执行得相当快,但程序在关闭前挂了大约一分钟。这是
我是一名优秀的程序员,十分优秀!