【算法设计与分析】04 函数的渐进的界

今天学习函数的渐进的界,会涉及多种数学符号。对以后学习分析算法复杂度有很大的帮助。

1 大 O O O符号

  • 定义: 设 f 和 g是定义域为自然数集N上的函数. 若存在正数 c 和 n0, 使得
    对一切 n \geq n0有:
    c f ( n ) c g ( n ) c\leq f(n) \leq cg(n) cf(n)cg(n)
    成立。则称f(n)的渐近的上届是g(n)。记作:
    f ( n ) = O ( g ( n ) ) f(n)=O(g(n)) f(n)=O(g(n))

例子:

  • f ( n ) = n 2 + 2 f(n)=n^2+2 f(n)=n2+2,则
    f ( n ) = O ( n 2 ) , c = 2 n 0 = 1 f(n)=O(n^2),取c=2,n_0=1即可 f(n)=O(n2),c=2n0=1
    f ( n ) = O ( n 3 ) , c = 3 n 0 = 2 f(n)=O(n^3),取c=3,n_0=2即可 f(n)=O(n3),c=3n0=2

对于大 O O O符号,有一下几条概念需要注意:

  1. f ( n ) = O ( g ( n ) ) , f ( n ) g ( n ) f(n)=O(g(n)),f(n)的阶不高于g(n)的阶 f(n)=O(g(n)),f(n)g(n)
  2. 可能存在多个正数c,只要指出其中一个即可,
  3. 对前面有限个值可以不满足不等式
  4. 常函数可以写成 O ( 1 ) O(1) O(1)

2 大 Ω \Omega Ω符号

  • 定义:设 f 和 g是定义域为自然数集N上的函数. 若存在正数 c 和 n0,使得对一切 n \geq n0有:

0 c g ( n ) f ( n ) 0\leq cg(n)\leq f(n) 0cg(n)f(n)
成立。则称 f ( n ) f(n) f(n)的渐近的下届是 g ( n ) g(n) g(n),记作:
f ( n ) = Ω ( g ( n ) ) f(n)=\Omega(g(n)) f(n)=Ω(g(n))

例子:

  • f ( n ) = n 2 + 2 f(n)=n^2+2 f(n)=n2+2,则
    f ( n ) = Ω ( n 2 ) , c = 1 n 0 = 1 f(n)=\Omega(n^2),取c=1,n_0=1即可 f(n)=Ω(n2),c=1n0=1
    f ( n ) = Ω ( 100 n ) , c = 1 / 100 n 0 = 1 f(n)=\Omega(100n),取c=1/100,n_0=1即可 f(n)=Ω(100n),c=1/100n0=1

对于 Ω \Omega Ω符号,需要注意以下几点:

  1. f ( n ) = Ω ( g ( n ) ) , f ( n ) g ( n ) f(n)=\Omega(g(n)),f(n)的阶不低于g(n)的阶 f(n)=Ω(g(n)),f(n)g(n)
  2. 可能存在多个正数c,只要指出其中一个即可
  3. 对前面有限个n值可以不满足上述不等式

3 小 o o o符号

  • 定义:设 f 和 g是定义域为自然数集N上的函数. 若对任意正数 c 都存在 n0,使得对一切 n \geq n0有:
    0 f ( n ) < c g ( n ) 0 \leq f(n) < c g(n) 0f(n)<cg(n)
    成立。则记作:
    f ( n ) = o ( g ( n ) ) f(n) = o(g(n)) f(n)=o(g(n))

例子:

  • f ( n ) = n 2 + 2 f(n)=n^2+2 f(n)=n2+2,则
    f ( n ) = o ( n 3 ) , c 1 n 2 + n < c n 3 n 0 = 2 f(n)=o(n^3),c\geq1显然成立。因为n^2+n<cn^3(n_0=2) f(n)=o(n3),c1n2+n<cn3n0=2
    1 > c > 0 n 0 > 2 c 对于1>c>0,取n_0>\left \lceil \frac{2}{c} \right \rceil即可,因为: 1>c>0n0>c2
    c n c n 0 > 2 cn\geq cn_0>2 cncn0>2 (当n n 0 \geq n_0 n0
    n 2 + n < 2 n 2 < c n 3 n^2+n<2n^2<cn^3 n2+n<2n2<cn3

对于小 o o o符号,需要注意以下几点:

  1. f ( n ) = o ( g ( n ) ) , f ( n ) g ( n ) f(n)=o(g(n)),f(n)的阶低于g(n)的阶 f(n)=o(g(n)),f(n)g(n)
  2. 对不同正数c,n0 不一样,c越小,n0越大。
  3. 对前面有限个n值可以不满足上述不等式

4 小 ω \omega ω符号

  • 定义:设 f 和 g是定义域为自然数集N上的函数. 若对任意正数 c 都存在 n0,使得对一切 n \geq n0有:
    0 c g ( n ) < f ( n ) 0 \leq cg(n) < f(n) 0cg(n)<f(n)
    成立。则记作:
    f ( n ) = ω ( g ( n ) ) f(n) = \omega(g(n)) f(n)=ω(g(n))

例子:

  • f ( n ) = n 2 + 2 f(n)=n^2+2 f(n)=n2+2,则
    f ( n ) = ω ( n ) , f ( n ) = ω ( n 2 ) , c = 2 n 0 使 n n 0 f(n)=\omega(n),不能写f(n)=\omega(n^2),因为取c=2,不存在n_0,使得对一切n\geq n_0有下式成立 f(n)=ω(n),f(n)=ω(n2),c=2n0使nn0
    c n 2 = 2 n 2 < n 2 + n c n^2 = 2n^2< n^2 + n (不成立) cn2=2n2<n2+n

对于小 ω \omega ω符号,需要注意以下几点:

  1. f ( n ) = ω ( g ( n ) ) , f ( n ) g ( n ) . f (n)=\omega (g(n)), f (n)的阶高于g(n) 的阶. f(n)=ω(g(n)),f(n)g(n).
  2. c , n 0 c n 0 . 对不同的正数c, n_0不等, c 越大n_0 越大. c,n0cn0.
  3. 对前面有限个 n 值可以 不满足不等式.

5 Θ \Theta Θ符号

  • 定义:若 f ( n ) = O ( g ( n ) ) f ( n ) = Ω ( g ( n ) ) , f(n)=O(g(n))且f(n)=\Omega(g(n)), f(n)=O(g(n))f(n)=Ω(g(n)),则记作:

f ( n ) = Θ ( g ( n ) ) f(n)=\Theta(g(n)) f(n)=Θ(g(n))

例子: f ( n ) = n 2 + n , g ( n ) = 100 n 2 f(n) =n^2 + n, g(n) =100n^2,那么有 f(n)=n2+n,g(n)=100n2
f ( n ) = Θ ( g ( n ) ) f(n)=\Theta (g(n)) f(n)=Θ(g(n))

注意以下两点:

  1. f ( n ) g ( n ) f(n)的阶与g(n)的阶相等 f(n)g(n)
  2. 对前面有限个n值,可以不满足条件

6 总结

  • 五种表示函数的阶的符号: O , Ω , o , ω , Θ O,\Omega,o,\omega,\Theta O,Ω,o,ω,Θ
  • 理解它们的定义
  • 如何用定义证明函数的阶?下一篇文章继续学习。
全部评论

相关推荐

只写bug的程序媛:才15,我招行20多万,建设银行50多万,说放弃就放弃
点赞 评论 收藏
分享
2024-11-18 16:08
福州大学 Java
影流之主:干10年不被裁,我就能拿别人一年的钱了,日子有盼头了
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务