- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试弄清楚如何给出最坏情况下的时间复杂度。我不确定我的分析。我读过嵌套的 for
循环 big O is n^2
;这对于内部带有 while
循环的 for
循环是否正确?
// A is an array of real numbers.
// The size of A is n. i,j are of type int, key is
// of type real.
Procedure IS(A)
for j = 2 to length[A]
{
key = A[ j ]
i = j-1
while i>0 and A[i]>key
{
A[i+1] = A[i]
i=i-1
}
A[i+1] = key
}
到目前为止我有:
j=2 (+1 op)
i>0 (+n ops)
A[i] > key (+n ops)
so T(n) = 2n+1?
但我不确定是否必须进入 while
和 for
循环来分析更坏情况下的时间复杂度...
现在我要证明它是紧束缚的,即Big theta。
我读到嵌套的 for
循环有 n^2
的大 O。 Big Theta 也是如此吗?如果不是,我将如何找到 Big Theta?!
**C1= C sub 1, C2= C sub 2, no= n naught都是正实数元素
为了找到 T(n)
,我查看了 j
的值并查看了 while 循环执行了多少次:
values of J: 2, 3, 4, ... n
Loop executes: 1, 2, 3, ... n
分析:
将 while 循环执行的总和识别为 (n(n+1))/2
我会将其指定为我的 T(n)
并证明它严格受 n^2
约束。即 n(n+1)/2= θ(n^2)
草稿:
Find C1, C2, no є R+ such that 0 ≤ C1(n^2) ≤ (n(n+1))/2 ≤ C2(n^2)for all n ≥ no
To make 0 ≤ C1(n) true, C1, no, can be any positive reals
To make C1(n^2) ≤ (n(n+1))/2, C1 must be ≤ 1
To make (n(n+1))/2 ≤ C2(n^2), C2 must be ≥ 1
PF:
Find C1, C2, no є R+ such that 0 ≤ C1(n^2) ≤ (n(n+1))/2 ≤ C2(n^2) for all n ≥ no
Let C1= 1/2, C2= 1 and no = 1.
证明 0 ≤ C1(n^2) 为真C1(n^2)= n^2/2
n^2/2≥ 无^2/2
⇒没有^2/2≥0
1/2 > 0
因此 C1(n^2) ≥ 0 被证明是正确的!
证明 C1(n^2) ≤ (n(n+1))/2 为真C1(n^2) ≤ (n(n+1))/2
n^2/2 ≤ (n(n+1))/2n^2 ≤ n(n+1)
n^2 ≤ n^2+n
0 ≤ n
我们知道这是真的,因为 n ≥ no = 1
因此 C1(n^2) ≤ (n(n+1))/2 被证明是正确的!
证明 (n(n+1))/2 ≤ C2(n^2) 为真(n(n+1))/2 ≤ C2(n^2)
(n+1)/2 ≤ C2(n)
n+1 ≤ 2 C2(n)
n+1 ≤ 2(n)
1 ≤ 2n-n
1 ≤ n(2-1) = n
1≤n
此外,我们知道这是真的,因为 n ≥ no = 1
因此根据 1、2 和 3,θ(n^2 )= (n(n+1))/2 为真,因为
0 ≤ C1(n^2) ≤ (n(n+1))/2 ≤ C2(n^2) 对于所有 n ≥ no
告诉我你们的想法……我正在努力理解这些 Material ,希望你们能提供意见!
最佳答案
您似乎正在实现 insertion sort algorithm ,维基百科称其为 O(N2)。
通常,在处理 Big-O 时,您会根据变量 N 而不是常量 C 来分解码件。对于您的情况,您需要做的就是查看循环。
你的两个循环是(最坏的情况):
for j=2 to length[A]
i=j-1
while i > 0
/*action*/
i=i-1
外层循环复杂度为O(N),因为它直接关系到元素个数。
请注意您的内循环如何取决于外循环的进度。这意味着(忽略差一问题)内循环和外循环的关系如下:
j's innervalue loops----- ----- 2 1 3 2 4 3 N N-1----- -----total (N-1)*N/2
所以遇到/*action*/
的总次数是(N2 - N)/2,也就是O(N2 ).
关于algorithm - 我如何找到时间复杂度 T(n) 并证明它是有界的(Big Theta)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/656745/
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: Big Theta Notation - what exactly does big Theta represent
我有一个作业要证明这些是对还是错: a) 150n^3 + 43n^2 + 50^n + 3 = Ω(n^5) b) n^10 + 30n^8 + 80n^6 = O(n^12) c) 55n + 3
我可以在 big.Int 上使用像 Text() 这样的方法,它工作正常,但是如果我返回一个 big.Int 然后使用“myfunc().Text()”会抛出一个错误,而如果我返回一个 * big.I
我正在用 PHP 开发一个网络应用程序,此时核心库的大小为 94kb。虽然我认为我现在是安全的,但多大才算太大?脚本的大小是否会成为一个问题,如果是这样,可以通过将脚本拆分为多个库来改善这一点吗? 我
我正在复习 Big-Oh 符号,但我在理解这个问题的解决方案时遇到了问题: Is 2n + 10 ≡ O(n)? Can we find c and n0? 2n + 10 = 10 n >= 10/
我最近陷入了争论/辩论中,我试图对正确的解决方案做出明确的判断。 众所周知, n! grows very quickly ,但究竟有多快,足以“隐藏”可能添加到其中的所有其他常量? 让我们假设我有这个
我很难找出这段代码的 Big-O 符号。 我需要找到两个 for 循环的符号。 public static int fragment(int n) { int sum = 0; for (in
给定两个函数: f(n)=O(log2n) 和 g(n)=O(log10n) 其中一个是否支配另一个? 最佳答案 请记住,任何碱基的对数都可以转换为仅以常数变化的公共(public)碱基。 因此它们都
经过修改,我们得出结论,时间复杂度实际上是O(2^n) 问题是时间复杂度是多少?是 O(2^n) 还是? 我相信这是因为 for 循环被认为运行了 n 次。然后嵌套的 while 循环运行 2^n 次
以下嵌套循环的 Big-O 时间复杂度是多少: for (int i = 0; i < N; i++) { for (int j = i + 1; j < N; j++) {
我很想知道经验丰富的 C 程序员认为可以按值传递的参数大小的上限是什么。 上下文:我有机会使用 2×2 矩阵,它位于一个结构体中: typedef struct { double a, b, c,
我很想知道经验丰富的 C 程序员认为可以按值传递的参数大小的上限是什么。 上下文:我有机会使用 2×2 矩阵,它位于一个结构体中: typedef struct { double a, b, c,
假设我们有一个问题,我们使用 X 算法实现了 O(n) 或 O(log n) 或 etc...。 n 的值何时大到我们必须考虑替代实现?让我们看看我是否可以更好地解释自己。 For n=10,000
这属于哪种 Big-O 表示法?我知道 setSearch() 和 removeAt() 是 O(n) 的顺序(假设它们是任意一种)。我知道如果没有 for 循环它肯定是 O(n),但是我很困惑如何计
这是我的问题,我已经设法为 a 部分提出了一个答案,但对于 b 部分,我对 b 部分的答案并不是很自信。 在最近的一起法庭案件中,一名法官以蔑视城市为由,下令第一天罚款 2 美元。 之后的每一天,直到
我正在尝试计算以下算法的大 O,但我很困惑,需要一些帮助: Algorithm 1. DFS(G,n) Input: G- the graph n- the current node 1
我们有一个使用 F5 BIG-IP 服务器进行负载平衡的潜在客户端。在确定我们是否可以将我们的产品与他们的负载均衡器干净地集成时,我开始查看 F5 提供的 API。问题是,如果没有 F5 服务器,我无
我正在尝试使用 react-big-calendar 包。 http://intljusticemission.github.io/react-big-calendar/examples/index.
我的任务是尝试找到给定 Java 方法的 big-O 和 big-Omega,但不知道如何找到。我知道 big-O 给出了上限,big-Omega 给出了下限,但是在查看程序(更不用说递归程序)时,我
我正在尝试确定以下陈述是对还是错。 如果 f(n) ∈ O(n) 且 g(n) ∈ Ω(n),则 f(n) + g(n) ∈ Θ(n)。 我想我理解添加相同的渐近 big-O。 O(n) + O(n)
我是一名优秀的程序员,十分优秀!